ZipFileSystemProvider 无法识别 JIMFS

JIMFS not recognized by ZipFileSystemProvider

我在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.run(ExecJavaMojo.java:293)
    at java.lang.Thread.run(Thread.java:785)

jimfs 未与 FileSystemProvider.installedProviders() 一起列出。它位于 ZipFileSystemProvider 之外的 class 加载器中,分别是 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 示例手动设置 class 加载器,但没有成功。 我是 运行 Linux。

使用了 jimfs 1.1(也尝试了 2.0-SNAPSHOT 修复 https://github.com/google/jimfs/commit/3299e69f75cf524e6d101d88e8c202c1b24bf25a for issue 31)。

如何让我的代码正常工作?

解法:
基于 SO 问题 ,我理解 class 加载程序问题是由于代码 运行 与 maven exec:java . 运行 使用普通 jar 的代码解决了问题!