java小程序读取文件目录,从签名的小程序中列出本地目录

下面的小程序被编译并打包到jar中,然后用自签名证书进行签名。

import java.applet.Applet;

import java.io.File;

import java.security.AccessController;

import java.security.PrivilegedAction;

import java.security.PrivilegedActionException;

public class Test extends Applet {

private static final long serialVersionUID = -3127185193501384816L;

private final class DirectoryLister implements PrivilegedAction {

private final String attachmentsFolder;

private DirectoryLister(String attachmentsFolder) {

this.attachmentsFolder = attachmentsFolder;

}

public File[] run() {

return new File(attachmentsFolder).listFiles();

}

}

public File[] getFiles() throws PrivilegedActionException {

String attachmentsFolder = getParameter("attachmentsFolder");

if (attachmentsFolder != null) {

return AccessController.doPrivileged(new DirectoryLister(

attachmentsFolder));

}

return null;

}

}

小程序实例化如下:

code="Test"

archive="applet.jar">

value="c:/test" />

小程序的用法如下:

var files = applet.getFiles();

for (var file in files) {

// Do something to file.

}

FF。遇到错误:

java.security.PrivilegedActionException: java.lang.reflect.InvocationTargetException

at java.security.AccessController.doPrivileged(Native Method)

at sun.plugin.liveconnect.SecureInvocation$2.run(Unknown Source)

at java.security.AccessController.doPrivileged(Native Method)

at sun.plugin.liveconnect.SecureInvocation.CallMethod(Unknown Source)

Caused by: java.lang.reflect.InvocationTargetException

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)

at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at sun.plugin.javascript.JSInvoke.invoke(Unknown Source)

at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source)

at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)

at java.lang.reflect.Method.invoke(Unknown Source)

at sun.plugin.javascript.JSClassLoader.invoke(Unknown Source)

at sun.plugin.liveconnect.PrivilegedCallMethodAction.run(Unknown Source)

... 4 more

Caused by: java.security.AccessControlException: access denied (java.io.FilePermission c:\test read)

at java.security.AccessControlContext.checkPermission(Unknown Source)

at java.security.AccessController.checkPermission(Unknown Source)

at java.lang.SecurityManager.checkPermission(Unknown Source)

at java.lang.SecurityManager.checkRead(Unknown Source)

at java.io.File.list(Unknown Source)

at java.io.File.listFiles(Unknown Source)

at Test$DirectoryLister.run(Test.java:20)

at Test$DirectoryLister.run(Test.java:1)

at java.security.AccessController.doPrivileged(Native Method)

at Test.getFiles(Test.java:28)

... 14 more

这就让我问一下,我是否仍然需要在Java主目录中的一个配置文件中显式地授予PrMS,以读取C:/Test.如果是这样,有人能给我指一个如何做这件事的指南吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值