簡體   English   中英

使用java.awt.Robot類在applet中進行屏幕捕獲時,java.security.AccessControlException

[英]java.security.AccessControlException when using java.awt.Robot class for screen capture in applet

每當客戶端單擊打印屏幕按鈕時,我都需要捕獲一個網頁屏幕以將其存儲在客戶端的計算機上。 為此,我通過在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.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"; 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM