2016-06-02 2 views
1

바이트 배열에서 jimfs (메모리 파일 시스템의 Google)으로 만든 zip 파일이 있습니다. ZipMemoryFileSystem으로 해당 파일을 열려고하면 공급자가 인식되지 않는다는 오류가 발생합니다. 내 코드는 다음과 같습니다 : jar:jimfs://bb2c779f-d327-4e2f-9841-bd04785f1365/file.zip :ZipFileSystemProvider가 JIMFS를 인식하지 못했습니다.

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는 같은입니다.

스택 추적 :

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) 

jimfs는 FileSystemProvider.installedProviders()에 표시되지 않습니다. 각각 ZipFileSystemProvider이 아닌 Thread.currentThread().getContextClassLoader() 인 경우와 FileSystemZipProvider 인 경우 ClassLoader.getSystemClassLoader().getParent() 인 별도의 클래스 로더에 있습니다.

공급자 인쇄는 다음과 같습니다 : I 수동 ClassLoaderTest 예를 들어 어떤 성공 jimfs에 따라 클래스 로더를 설정하기 위해 노력했다

IM Provider:[email protected] IM Scheme:jimfs IM Class Loader:[email protected] 
Installed Provider:[email protected] Scheme:file Class Loader:null 
Installed Provider:[email protected] Scheme:jar Class Loader:[email protected] 

. Linux에서 실행 중입니다.

사용 된 jimfs 1.1 (문제가 31 인 경우 https://github.com/google/jimfs/commit/3299e69f75cf524e6d101d88e8c202c1b24bf25a의 2.0 스넵 샷 시도).

어떻게 코드를 작동시킬 수 있습니까?

답변

관련 문제