我从一个字节数组中创建了一个在jimfs (内存文件系统中的google)中创建的zip文件。当试图用ZipMemoryFileSystem打开该文件时,我会得到一个错误,无法识别提供程序。我的代码如下:
public static void test(byte[] document) {
try {
try (FileSystem memoryFileSystem = Jimfs.newFileSystem(Configuration.unix())) {
Files.write(memoryFileSystem.getPath("/file.zip"), document);
URI uri = URI.create("jar:" + memoryFileSystem.getPath("/file.zip").toUri());
Map<String, String> env = Collections.singletonMap("create", "false");
try (FileSystem zipfs = FileSystems.newFileSystem(uri, env)) {
//do something
} catch (Exception e) {
e.printStackTrace();
}
}
} catch (IOException e) {
e.printStackTrace();
}
}URI类似于:jar:jimfs://bb2c779f-d327-4e2f-9841-bd04785f1365/file.zip。
堆栈跟踪是:
java.nio.file.FileSystemNotFoundException: Provider "jimfs" not installed
at java.nio.file.Paths.get(Paths.java:158)
at com.sun.nio.zipfs.ZipFileSystemProvider.uriToPath(ZipFileSystemProvider.java:97)
at com.sun.nio.zipfs.ZipFileSystemProvider.newFileSystem(ZipFileSystemProvider.java:119)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:337)
at java.nio.file.FileSystems.newFileSystem(FileSystems.java:287)
at office.ImfsTest.test(ImfsTest.java:88)
at office.ImfsTest.main(ImfsTest.java:58)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:95)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:55)
at java.lang.reflect.Method.invoke(Method.java:508)
at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:293)
at java.lang.Thread.run(Thread.java:785)FileSystemProvider.installedProviders()中没有列出jimfs。它位于一个独立的类加载器中,而不是ZipFileSystemProvider,分别是Thread.currentThread().getContextClassLoader()和ClassLoader.getSystemClassLoader().getParent()的FileSystemZipProvider。
提供者打印如下:
IM Provider:com.google.common.jimfs.JimfsFileSystemProvider@ed301b1f IM Scheme:jimfs IM Class Loader:java.net.URLClassLoader@4940e7a2
Installed Provider:sun.nio.fs.LinuxFileSystemProvider@d83a6d85 Scheme:file Class Loader:null
Installed Provider:com.sun.nio.zipfs.ZipFileSystemProvider@110a4ec7 Scheme:jar Class Loader:sun.misc.Launcher$ExtClassLoader@59a155ab我尝试基于jimfs ClassLoaderTest示例手动设置类加载器,但没有成功。我在Linux上运行。
使用jimfs 1.1 (也尝试了2.0-快照与修复https://github.com/google/jimfs/commit/3299e69f75cf524e6d101d88e8c202c1b24bf25a的问题31)。
我怎么能让我的代码工作呢?
发布于 2016-06-03 06:48:48
解决方案:
基于因此发布的如何在运行exec:java时注册SPI实现,我理解类加载程序问题是由于代码是使用maven exec:java运行的。使用普通jar运行代码解决了问题!
https://stackoverflow.com/questions/37603205
复制相似问题