使用java.awt.Robot类在applet中进行屏幕捕获时,java.security.AccessControlException

每当客户端单击打印屏幕按钮时,我都需要捕获一个网页屏幕以将其存储在客户端的计算机上.为此,我通过在jsp页面中嵌入带有签名的小程序(受信任的小程序)来进行搜索.因此,我正在尝试为独立的Java类使用一个简单的applet.成功后,我可以在签署了applet后尝试使用jsp.
我试过的是:

import java.applet.Applet;  
import java.awt.Graphics;  
import java.util.Date;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.awt.Dimension;
import java.awt.Rectangle;
import java.awt.Robot;
import java.awt.Toolkit;
import javax.swing.ImageIcon;
/* <applet code = MyApplet.class width="500" height="500">Java Applet for screen capture</applet>  */



public class MyApplet extends Applet {  

  /* Applet Life cycle Methods */  
  public void start()
  { 
   try{
   // capture the whole screen
   BufferedImage screencapture = new Robot().createScreenCapture(new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()) );
   // Save as JPEG
   File file = new File("D:/screencapture.jpg");
   ImageIO.write(screencapture, "jpg", file);
   System.out.println("screen capture finished : ");
     }//try closing...
     catch(Exception e)
     {
       System.out.println("screen capture error : ");
       e.printStackTrace();
     }//catch closing...  
   }//start closing...

 public void stop()
  {  

  }   
}  

我得到这个:

java.security.AccessControlException: access denied ("java.awt.AWTPermission" "createRobot")
        at java.security.AccessControlContext.checkPermission(AccessControlContext.java:366)
        at java.security.AccessController.checkPermission(AccessController.java:560)
        at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
        at java.awt.Robot.checkRobotAllowed(Robot.java:170)
        at java.awt.Robot.init(Robot.java:134)
        at java.awt.Robot.<init>(Robot.java:96)
        at MyApplet.start(MyApplet.java:23)
        at sun.applet.AppletPanel.run(AppletPanel.java:474)
        at java.lang.Thread.run(Thread.java:722)

任何帮助,任何想法都会得到应用.

解决方法:

我知道问题一年后我正在挖掘恐龙,但我一直面临着同样的问题.就像有人说的那样,更改策略文件是个坏主意(对于某些用户来说也不舒服,就我而言,这是完全不可接受的解决方案).

我一直在使用有效清单的签名小程序中遇到相同的问题.问题出在我调用安全性相关方法的方式上.在这种情况下,您应该替换以下行:

 BufferedImage screencapture = new Robot().createScreenCapture(new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()) );

BufferedImage screencapture = AccessController.doPrivileged(new PrivilegedAction<BufferedImage >() {
    @Override
    public BufferedImage run(){
        return new Robot().createScreenCapture(new Rectangle(Toolkit.getDefaultToolkit().getScreenSize()) );
    }
});

这是干净的方法.在appled中使用有效的证书签名,并在mannifest和jnpl文件中输入正确的安全性,即可正常运行.

上一篇:java-调整Jframe大小时如何停止auto-repaint()


下一篇:Java最终类中受保护方法的用例是什么?