我试图统一代码以列出文件,无论它们是在目录中还是在类路径中。
我可以获得资源位置的URL:
URI uri = FontManagerTestUtils.class.getResource("/fonts").toURI();
FileSystem fileSystem =
FileSystems.newFileSystem(uri, Collections.emptyMap());
但是安全经理不喜欢它:
java.security.AccessControlException: access denied ("java.io.FilePermission" "/Users/tester/.gradle/caches/modules-2/files-2.1/com.acme.utilities/acme-utils/2.0.4/2c3dd60154b9f63c52ee0defe82422c2987f69b5/acme-utils-2.0.4.jar" "write")
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:472)
at java.security.AccessController.checkPermission(AccessController.java:884)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:549)
at java.lang.SecurityManager.checkWrite(SecurityManager.java:979)
at sun.nio.fs.UnixPath.checkWrite(UnixPath.java:801)
at sun.nio.fs.UnixFileSystemProvider.checkAccess(UnixFileSystemProvider.java:294)
at java.nio.file.Files.isAccessible(Files.java:2455)
at java.nio.file.Files.isWritable(Files.java:2521)
at com.sun.nio.zipfs.ZipFileSystem.<init>(ZipFileSystem.java:125)
at com.sun.nio.zipfs.ZipFileSystemProvider.newFileSystem(ZipFileSystemProvider.java:117)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:326)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:276)
不过,我并不是特别打算写到jar中,而且我的安全策略确实允许从类路径上的jar文件中读取,所以有一种方法可以告诉它不要用写访问权限打开它吗?