【问题标题】:java.security.AccessControlException when using java.awt.Robot class for screen capture in applet在小程序中使用 java.awt.Robot 类进行屏幕捕获时出现 java.security.AccessControlException
【发布时间】:2014-10-23 21:58:25
【问题描述】:

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

任何帮助,任何想法都会被应用。

【问题讨论】:

    标签: java applet awt awtrobot accesscontrolexception


    【解决方案1】:

    我知道问题发生一年后我正在挖掘恐龙,但我一直面临同样的问题。正如有人所说,更改策略文件是一个非常糟糕的主意(对于某些用户来说也很不舒服,而且就我而言,这是完全不可接受的解决方案)。

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

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

    这是一种干净的方式。在使用有效证书签名的苹果中,在清单和 jnpl 文件中具有正确的安全条目,它可以完美运行。

    【讨论】:

      【解决方案2】:

      我解决了这个问题。 我所做的只是将这些行粘贴到 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"; 
      

      【讨论】:

      • “我解决了这个问题” 不是真的。您只是将问题推迟到生产。在生产时,策略文件将不实用,并且该应用程序。需要数字签名(由您)和信任(由最终用户)才能使用Robot
      • @Andrew:我找不到你?您能否再解释一下为什么它就像“将问题推迟到生产”?由于我在一家基于激光雷达技术的 GIS 扫描公司工作并进行 Java 开发,所以我是一支单人军队(除了在线帮助外,没有人可以帮助我)。
      • 您不能指望最终用户会弄乱策略文件。这是不安全的,而且超出了他们的理解范围。因此,要让受信任的小程序在最终用户的机器上运行,需要对其进行数字签名。由于它需要进行数字签名,您不妨现在就解决这个问题。 Ant 构建脚本可以对每个构建的类进行 Jar 和签名。
      • 请看一下,如果我有误导,请纠正我:coderanch.com/t/607189/Applets/java/…
      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-11-03
      • 1970-01-01
      • 2015-03-31
      • 2019-02-03
      • 2012-08-26
      • 2012-05-16
      • 1970-01-01
      相关资源
      最近更新 更多