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)
======================================================================
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)
======================================================================