mirror of
https://gitee.com/dromara/hutool.git
synced 2025-04-05 17:37:59 +08:00
新增zip文件解压大小限制,防止zip炸弹
This commit is contained in:
parent
a8c6cf94cd
commit
bf98387000
@ -30,6 +30,7 @@
|
||||
* 【core 】 完善了codec包下一些方法的入参空校验(pr#719@Gitee)
|
||||
* 【extra 】 完善QrCodeUtil对于DATA_MATRIX生成的形状随机不可指定的功能(pr#722@Gitee)
|
||||
* 【core 】 修改NetUtil.ipv6ToBigInteger,原方法标记为过期(pr#2485@Github)
|
||||
* 【core 】 ZipUtil新增zip文件解压大小限制,防止zip炸弹(pr#726@Gitee)
|
||||
*
|
||||
### 🐞Bug修复
|
||||
* 【core 】 修复CollUtil里面关于可变参数传null造成的crash问题(pr#2428@Github)
|
||||
|
@ -124,7 +124,7 @@ public class ZipUtil {
|
||||
}
|
||||
} catch (FileAlreadyExistsException ignored) {
|
||||
// 不覆盖情况下,文件已存在, 跳过
|
||||
} catch (IOException e){
|
||||
} catch (IOException e) {
|
||||
throw new IORuntimeException(e);
|
||||
}
|
||||
}
|
||||
@ -262,6 +262,7 @@ public class ZipUtil {
|
||||
*/
|
||||
public static File zip(File zipFile, Charset charset, boolean withSrcDir, FileFilter filter, File... srcFiles) throws IORuntimeException {
|
||||
validateFiles(zipFile, srcFiles);
|
||||
//noinspection resource
|
||||
ZipWriter.of(zipFile, charset).add(withSrcDir, filter, srcFiles).close();
|
||||
return zipFile;
|
||||
}
|
||||
@ -432,6 +433,7 @@ public class ZipUtil {
|
||||
* @since 5.5.2
|
||||
*/
|
||||
public static File zip(File zipFile, Charset charset, Resource... resources) throws UtilException {
|
||||
//noinspection resource
|
||||
ZipWriter.of(zipFile, charset).add(resources).close();
|
||||
return zipFile;
|
||||
}
|
||||
@ -548,15 +550,7 @@ public class ZipUtil {
|
||||
* @since 4.5.8
|
||||
*/
|
||||
public static File unzip(ZipFile zipFile, File outFile) throws IORuntimeException {
|
||||
if (outFile.exists() && outFile.isFile()) {
|
||||
throw new IllegalArgumentException(
|
||||
StrUtil.format("Target path [{}] exist!", outFile.getAbsolutePath()));
|
||||
}
|
||||
|
||||
try (final ZipReader reader = new ZipReader(zipFile)) {
|
||||
reader.readTo(outFile);
|
||||
}
|
||||
return outFile;
|
||||
return unzip(zipFile, outFile, -1);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -564,23 +558,27 @@ public class ZipUtil {
|
||||
*
|
||||
* @param zipFile zip文件,附带编码信息,使用完毕自动关闭
|
||||
* @param outFile 解压到的目录
|
||||
* @param size 警戒线大小(B)
|
||||
* @param limit 限制解压文件大小(单位B)
|
||||
* @return 解压的目录
|
||||
* @throws IORuntimeException IO异常
|
||||
* @since 5.8.5
|
||||
*/
|
||||
public static File unzip(ZipFile zipFile, File outFile, long size) throws IORuntimeException {
|
||||
public static File unzip(ZipFile zipFile, File outFile, long limit) throws IORuntimeException {
|
||||
if (outFile.exists() && outFile.isFile()) {
|
||||
throw new IllegalArgumentException(
|
||||
StrUtil.format("Target path [{}] exist!", outFile.getAbsolutePath()));
|
||||
}
|
||||
Enumeration<? extends ZipEntry> zipEntries = zipFile.entries();
|
||||
long zipFileSize = 0L;
|
||||
while(zipEntries.hasMoreElements()) {
|
||||
ZipEntry zipEntry = zipEntries.nextElement();
|
||||
zipFileSize += zipEntry.getSize();
|
||||
if (zipFileSize > size) {
|
||||
throw new IllegalArgumentException("The file size exceeds the limit");
|
||||
|
||||
// pr#726@Gitee
|
||||
if (limit > 0) {
|
||||
final Enumeration<? extends ZipEntry> zipEntries = zipFile.entries();
|
||||
long zipFileSize = 0L;
|
||||
while (zipEntries.hasMoreElements()) {
|
||||
ZipEntry zipEntry = zipEntries.nextElement();
|
||||
zipFileSize += zipEntry.getSize();
|
||||
if (zipFileSize > limit) {
|
||||
throw new IllegalArgumentException("The file size exceeds the limit");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user