每当客户点击打印屏幕按钮时,我都需要捕获网页屏幕以将其存储在客户端的计算机上。为此,我用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)
任何帮助,任何想法都会得到满足。
答案 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";