java 安全策略没有按预期工作,总是给出 AccessControlException

java security policy doesn't work as expected, always give AccessControlException

首先,我有这个工作代码:

import java.io.FileWriter;
import java.io.IOException;
public class TestPolicy {
    public static void main(String[] args) {
        FileWriter writer;
        try {
            writer = new FileWriter("testPolicy.txt");
            writer.write("hello1");
            writer.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

它 运行 适合

D:\Documents\myproject\mynet\mytest\java\security\target\classes>java -classpath . TestPolic

它会生成一个名为 [testPolicy.txt]

的新文件

然后我添加了一个../../src/myPolicy.txt,内容为:

grant codeBase "file:D:\Documents\myproject\mynet\mytest\java\security\target\classes*" {
    permission java.io.FilePermission "testPolicy.txt", "read,write";
};

没想到,只要我指定了"read,write"权限,应该也会运行的吧。但它 运行 有例外:

D:\Documents\myproject\mynet\mytest\java\security\target\classes>java -classpath . -Djava.security.manager -Djava.security.policy=../../src/myPolicy.txt TestPolicy
Exception in thread "main" java.security.AccessControlException: access denied ("java.io.FilePermission" "testPolicy.txt" "write")
        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.checkWrite(Unknown Source)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at java.io.FileOutputStream.<init>(Unknown Source)
        at java.io.FileWriter.<init>(Unknown Source)
        at TestPolicy.main(TestPolicy.java:8)

我哪里错了,如何解决?

非常感谢。

myPolicy.txtcodeBase URL 中使用正斜杠而不是反斜杠。您可能还需要在 "classes" 和“*”之间添加一个斜线。

根据 PolicyFiles documentation:

Note: a codeBase value is a URL and thus should always utilize slashes (never backslashes) as the directory separator, even when the code source is actually on a Windows system. Thus, if the source location for code on a Windows system is actually C:\somepath\api\, then the policy codeBase entry should look like:

grant codeBase "file:/C:/somepath/api/" {
    ...
};