标签:style io ar 使用 sp for java strong on
在applet项目中,总会遇到java.security.AccessControlException:这类异常.
在这里总结一下applet会遇到这些异常的情况和解决办法.
一因
产生这个异常都是由java的安全性所致.
Applet属于网页加载的代码,所以被限定了安全级别,也就是说,很多事,没通过一些特定权限的授予,都是不能干的.以下是被禁止的操作:
不能访问本地文件,不能读取或者写入,深圳不能获得文件相关信息(是否存在,修改日期)
不能访问任何内存地址
不能打印文档
不能启动客户端的其他程序,也就是不能执行System.exec()或者Runtime.exec()
不能获取系统参数,System.getProperty(),那更加不能设置系统属性了
不能定义或使用ClassLoader,SecurityManager,Content-HandlerFactory,SocketImplFactory或者URLStreamHandlerFactory的新实例,必须是已经存在的实例.
不能建立除加载此applet主机外的链接,也就是只能连加载此applet的主机
虽说这些限制对于经过数字签名的代码会有所放松,但有时候不一定灵
二果
解决办法就是你把所有这些操作,加到一个特权类里面,表示这些操作享有特权.
AccessController.doPrivileged(new PrivilegedAction() { public Object run() { // privileged code goes here, for example: System.getProperty(….) returnnull;// nothing to return } });
标签:style io ar 使用 sp for java strong on
原文地址:http://blog.csdn.net/ustcefish/article/details/41940501