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

时间:2013-03-13 09:36:33

标签: java applet awt awtrobot accesscontrolexception

每当客户点击打印屏幕按钮时,我都需要捕获网页屏幕以将其存储在客户端的计算机上。为此,我用google搜索并通过在我的jsp页面中嵌入带有签名(可信applet)的applet来实现这一点。所以我尝试使用一个简单的applet来实现一个独立的java类。成功后,我可以在签署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)

任何帮助,任何想法都会得到满足。

2 个答案:

答案 0 :(得分:2)

我知道我在问题发生后一年就挖了一只恐龙,但我一直面临着同样的问题。正如有人所说,改变政策档案是一个非常糟糕的想法(对某些用户来说也不舒服,在我的情况下,这是完全不可接受的解决方案)。

我在签名小程序中遇到了与有效mannifest相同的问题。问题出在我调用安全相关方法的方式上。在这种情况下,你应该替换line:

 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()) );
    }
});

这是干净的方式。在appledled使用有效的certyficate签名,在mannifest和jnpl文件中使用正确的安全性条目,它完美无缺。

答案 1 :(得分:0)

我解决了这个问题。 我所做的只是在java.policy文件中粘贴这些行(只需在java安装文件夹中搜索此文件,您将在3个位置获取它,并且需要在所有文件中将其粘贴到最后)

permission java.awt.AWTPermission "createRobot"; 
permission java.awt.AWTPermission "accessClipboard"; 
permission java.awt.AWTPermission "accessEventQueue"; 
permission java.awt.AWTPermission "showWindowWithoutWarningBanner"; 
permission java.awt.AWTPermission "readDisplayPixels", "read"; 
permission java.io.FilePermission "<<ALL FILES>>", "read, write, delete, execute";