Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-4721553

print to file fails because of privilege exception

XMLWordPrintable

    • Icon: Enhancement Enhancement
    • Resolution: Won't Fix
    • Icon: P3 P3
    • 7
    • 1.2.0
    • deploy
    • 1.0.1
    • sparc
    • solaris_8

      Name: nt126004 Date: 07/26/2002


      FULL PRODUCT VERSION :
      java version "1.4.1-beta"
      Java(TM) 2 Runtime Environment, Standard Edition (build 1.4.1-beta-b14)
      Java HotSpot(TM) Client VM (build 1.4.1-beta-b14, mixed mode)

      FULL OPERATING SYSTEM VERSION :
      SunOS sun 5.8 Generic_108528-13 sun4u sparc SUNW,Ultra-1
       
      ADDITIONAL OPERATING SYSTEMS :


      A DESCRIPTION OF THE PROBLEM :
      JWS 1.2 beta provides a PrintService.
      When using the PrintService to print to a file you get
      exceptions
      like this:
      Exception occurred during event dispatching:
      java.security.AccessControlException: access denied
      (java.io.FilePermission /home/mswanson/3DModels read)
       
      JavaWebStart should ask for read/write permission to the user's
      home directory so printing to file works. OR, JavaWebStart should
      NOT allow printing to file.

      The spec states exactly the permissions that are given,
      and the java.io.FilePermission required to print to a file isn't one of them.
      No test case or jnlp file is required as this is documented functionality.
      The bug is that when printing to file, the permission should be asked for and
      it is not.


      STEPS TO FOLLOW TO REPRODUCE THE PROBLEM :
      1.Use JWS1.2beta to print to a file.
      2.
      3.

      EXPECTED VERSUS ACTUAL BEHAVIOR :
      Expected: JWS should ask for permission to read/write to the
      user's home directory before writing the file.
       
      Actual: Stack trace.


      ERROR MESSAGES/STACK TRACES THAT OCCUR :
      Exception occurred during event dispatching:
      java.security.AccessControlException: access denied (java.io.FilePermission
      /home/mswanson/3DModels read)
          at
      java.security.AccessControlContext.checkPermission(AccessControlContext.java:270)
          at java.security.AccessController.checkPermission(AccessController.java:401)
          at java.lang.SecurityManager.checkPermission(SecurityManager.java:542)
          at java.lang.SecurityManager.checkRead(SecurityManager.java:887)
          at java.io.File.exists(File.java:677)
          at sun.awt.shell.ShellFolder.exists(ShellFolder.java:257)
          at
      javax.swing.filechooser.FileSystemView.getSystemDisplayName(FileSystemView.java:140)
          at
      javax.swing.plaf.basic.BasicFileChooserUI$BasicFileView.getName(BasicFileChooserUI.java:1005)
          at javax.swing.JFileChooser.getName(JFileChooser.java:1437)
          at
      javax.swing.plaf.metal.MetalFileChooserUI$FileRenderer.getListCellRendererComponent(MetalFileChooserUI.java:1136)
          at javax.swing.plaf.basic.BasicListUI.updateLayoutState(BasicListUI.java:1147)
          at javax.swing.plaf.basic.BasicListUI.maybeUpdateLayoutState(BasicListUI.java:1097)
          at javax.swing.plaf.basic.BasicListUI.paint(BasicListUI.java:162)
          at com.incors.plaf.kunststoff.KunststoffListUI.update(KunststoffListUI.java:72)
          at javax.swing.JComponent.paintComponent(JComponent.java:541)
          at javax.swing.JComponent.paint(JComponent.java:808)
          at javax.swing.JComponent.paintChildren(JComponent.java:647)
          at javax.swing.JComponent.paint(JComponent.java:817)
          at javax.swing.JViewport.paint(JViewport.java:707)
          at javax.swing.JComponent.paintChildren(JComponent.java:647)
          at javax.swing.JComponent.paint(JComponent.java:817)
          at javax.swing.JComponent.paintWithOffscreenBuffer(JComponent.java:4771)
          at javax.swing.JComponent.paintDoubleBuffered(JComponent.java:4724)
          at javax.swing.JComponent._paintImmediately(JComponent.java:4668)
          at javax.swing.JComponent.paintImmediately(JComponent.java:4477)
          at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:410)
          at
      javax.swing.SystemEventQueueUtilities$ComponentWorkRequest.run(SystemEventQueueUtilities.java:117)
          at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:178)
          at java.awt.EventQueue.dispatchEvent(EventQueue.java:448)
          at
      java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.java:197)
          at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
          at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:140)
          at java.awt.Dialog.show(Dialog.java:538)
          at javax.swing.JFileChooser.showDialog(JFileChooser.java:696)
          at sun.print.ServiceDialog.showFileChooser(ServiceDialog.java:311)
          at sun.print.ServiceDialog.actionPerformed(ServiceDialog.java:268)
          at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1764)
          at
      javax.swing.AbstractButton$ForwardActionEvents.actionPerformed(AbstractButton.java:1817)
          at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:419)
          at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:257)
          at
      javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:245)
          at java.awt.Component.processMouseEvent(Component.java:5093)
          at java.awt.Component.processEvent(Component.java:4890)
          at java.awt.Container.processEvent(Container.java:1566)
          at java.awt.Component.dispatchEventImpl(Component.java:3598)
          at java.awt.Container.dispatchEventImpl(Container.java:1623)
          at java.awt.Component.dispatchEvent(Component.java:3439)
          at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:3450)
          at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3165)
          at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3095)
          at java.awt.Container.dispatchEventImpl(Container.java:1609)
          at java.awt.Window.dispatchEventImpl(Window.java:1585)
          at java.awt.Component.dispatchEvent(Component.java:3439)
          at java.awt.EventQueue.dispatchEvent(EventQueue.java:450)
          at
      java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.java:197)
          at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
          at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:140)
          at java.awt.Dialog.show(Dialog.java:538)
          at javax.print.ServiceUI.printDialog(ServiceUI.java:164)
          at sun.print.RasterPrinterJob$2.run(RasterPrinterJob.java:663)
          at java.security.AccessController.doPrivileged(Native Method)
          at sun.print.RasterPrinterJob.printDialog(RasterPrinterJob.java:627)
          at sun.print.PSPrinterJob.printDialog(PSPrinterJob.java:473)
          at com.sun.jnlp.PrintServiceImpl$3.run(PrintServiceImpl.java:107)
          at java.security.AccessController.doPrivileged(Native Method)
          at com.sun.jnlp.PrintServiceImpl.doPrinting(PrintServiceImpl.java:94)
          at com.sun.jnlp.PrintServiceImpl.print(PrintServiceImpl.java:86)
          at
      com.wss.calendar.client.swing.ScheduleWorldFrame.print(ScheduleWorldFrame.java:1063)
          at
      com.wss.calendar.client.swing.ScheduleWorldFrame.jMenuItemFilePrint_actionPerformed(ScheduleWorldFrame.java:1037)
          at
      com.wss.calendar.client.swing.ScheduleWorldFrame$40.actionPerformed(ScheduleWorldFrame.java:437)
          at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1764)
          at
      javax.swing.AbstractButton$ForwardActionEvents.actionPerformed(AbstractButton.java:1817)
          at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:419)
          at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:257)
          at javax.swing.AbstractButton.doClick(AbstractButton.java:289)
          at javax.swing.plaf.basic.BasicMenuItemUI.doClick(BasicMenuItemUI.java:1109) at
      javax.swing.plaf.basic.BasicMenuItemUI$MouseInputHandler.mouseReleased(BasicMenuItemUI.java:943)
          at java.awt.Component.processMouseEvent(Component.java:5093)
          at java.awt.Component.processEvent(Component.java:4890)
          at java.awt.Container.processEvent(Container.java:1566)
          at java.awt.Component.dispatchEventImpl(Component.java:3598)
          at java.awt.Container.dispatchEventImpl(Container.java:1623)
          at java.awt.Component.dispatchEvent(Component.java:3439)
          at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:3450)
          at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3165)
          at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3095)
          at java.awt.Container.dispatchEventImpl(Container.java:1609)
          at java.awt.Window.dispatchEventImpl(Window.java:1585)
          at java.awt.Component.dispatchEvent(Component.java:3439)
          at java.awt.EventQueue.dispatchEvent(EventQueue.java:450)
          at
      java.awt.EventDispatchThread.pumpOneEventForHierarchy(EventDispatchThread.java:197)
          at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:150)
          at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:144)
          at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:136)
          at java.awt.EventDispatchThread.run(EventDispatchThread.java:99)
       


      REPRODUCIBILITY :
      This bug can be reproduced always.

      ---------- BEGIN SOURCE ----------
      PageFormat pageFormat = printService.getDefaultPage();
                  PrintUtilities printUtilities = new PrintUtilities(this);
                  printService.print(printUtilities);
       
      Note: PrintUtilities is just a simple class that implements Printable. The freely
      available source is available here:
      http://www.apl.jhu.edu/~hall/java/Swing-Tutorial/Swing-Tutorial-Printing.html
       
      Note: (this) is a simple JDialog.
       
      Note: printService is a JWS1.2beta PrintService.

      ---------- END SOURCE ----------
      (Review ID: 158992)
      ======================================================================

            enicholasunw Ethan Nicholas (Inactive)
            nthompsosunw Nathanael Thompson (Inactive)
            Votes:
            0 Vote for this issue
            Watchers:
            2 Start watching this issue

              Created:
              Updated:
              Resolved:
              Imported:
              Indexed: