mirror of
				https://gitee.com/dromara/hutool.git
				synced 2025-10-27 03:09:40 +08:00 
			
		
		
		
	fix code
This commit is contained in:
		| @@ -55,7 +55,8 @@ public class SevenZExtractor implements Extractor, RandomAccess { | ||||
| 	 */ | ||||
| 	public SevenZExtractor(final File file, final char[] password) { | ||||
| 		try { | ||||
| 			this.sevenZFile = new SevenZFile(file, password); | ||||
| 			this.sevenZFile = SevenZFile.builder() | ||||
| 				.setFile(file).setPassword(password).get(); | ||||
| 		} catch (final IOException e) { | ||||
| 			throw new IORuntimeException(e); | ||||
| 		} | ||||
| @@ -97,7 +98,8 @@ public class SevenZExtractor implements Extractor, RandomAccess { | ||||
| 	 */ | ||||
| 	public SevenZExtractor(final SeekableByteChannel channel, final char[] password) { | ||||
| 		try { | ||||
| 			this.sevenZFile = new SevenZFile(channel, password); | ||||
| 			this.sevenZFile = SevenZFile.builder() | ||||
| 				.setSeekableByteChannel(channel).setPassword(password).get(); | ||||
| 		} catch (final IOException e) { | ||||
| 			throw new IORuntimeException(e); | ||||
| 		} | ||||
| @@ -160,7 +162,7 @@ public class SevenZExtractor implements Extractor, RandomAccess { | ||||
| 			} else if (entry.hasStream()) { | ||||
| 				// 读取entry对应数据流 | ||||
| 				// 此处直接读取而非调用sevenZFile.getInputStream(entry),因为此方法需要遍历查找entry对应位置,性能不好。 | ||||
| 				FileUtil.writeFromStream(new Seven7EntryInputStream(sevenZFile, entry), outItemFile); | ||||
| 				FileUtil.copy(new Seven7EntryInputStream(sevenZFile, entry), outItemFile); | ||||
| 			} else { | ||||
| 				// 无数据流的文件创建为空文件 | ||||
| 				FileUtil.touch(outItemFile); | ||||
|   | ||||
| @@ -39,7 +39,7 @@ import java.util.function.Predicate; | ||||
|  */ | ||||
| public class StreamExtractor implements Extractor { | ||||
|  | ||||
| 	private final ArchiveInputStream in; | ||||
| 	private final ArchiveInputStream<?> in; | ||||
|  | ||||
| 	/** | ||||
| 	 * 构造 | ||||
| @@ -81,7 +81,7 @@ public class StreamExtractor implements Extractor { | ||||
| 	 */ | ||||
| 	public StreamExtractor(final Charset charset, final String archiverName, InputStream in) { | ||||
| 		if (in instanceof ArchiveInputStream) { | ||||
| 			this.in = (ArchiveInputStream) in; | ||||
| 			this.in = (ArchiveInputStream<?>) in; | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| @@ -109,7 +109,7 @@ public class StreamExtractor implements Extractor { | ||||
|  | ||||
| 	@Override | ||||
| 	public InputStream getFirst(final Predicate<ArchiveEntry> predicate) { | ||||
| 		final ArchiveInputStream in = this.in; | ||||
| 		final ArchiveInputStream<?> in = this.in; | ||||
| 		ArchiveEntry entry; | ||||
| 		try { | ||||
| 			while (null != (entry = in.getNextEntry())) { | ||||
| @@ -156,7 +156,7 @@ public class StreamExtractor implements Extractor { | ||||
| 	 */ | ||||
| 	private void extractInternal(final File targetDir, final Predicate<ArchiveEntry> predicate) throws IOException { | ||||
| 		Assert.isTrue(null != targetDir && ((!targetDir.exists()) || targetDir.isDirectory()), "target must be dir."); | ||||
| 		final ArchiveInputStream in = this.in; | ||||
| 		final ArchiveInputStream<?> in = this.in; | ||||
| 		ArchiveEntry entry; | ||||
| 		File outItemFile; | ||||
| 		while (null != (entry = in.getNextEntry())) { | ||||
| @@ -173,7 +173,7 @@ public class StreamExtractor implements Extractor { | ||||
| 				//noinspection ResultOfMethodCallIgnored | ||||
| 				outItemFile.mkdirs(); | ||||
| 			} else { | ||||
| 				FileUtil.writeFromStream(in, outItemFile, false); | ||||
| 				FileUtil.copy(in, outItemFile); | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Looly
					Looly