用java解压一个zip,如果这个zip文件是损坏的会报错,求解决方法

wineer200 2012-07-31 04:27:49
用java解压一个zip,如果这个zip文件是损坏的会报错,求解决方法
二话不说,上代码
	/**
* 解压文件
*
* @param zipFilename
* 需要解压的文件
* @param outputDirectory
* 解压后的文件
* @throws IOException
*/
public synchronized static void unzip(String zipFilename, String outputDirectory)
throws Exception {
InputStream in = null;
try {
File outFile = new File(outputDirectory);
if (!outFile.exists()) {
outFile.mkdirs();
}

ZipFile zipFile = new ZipFile(zipFilename);
// Enumeration en = zipFile.getEntries();
Enumeration en = zipFile.entries();
ZipEntry zipEntry = null;
while (en.hasMoreElements()) {
zipEntry = (ZipEntry) en.nextElement();
if (zipEntry.isDirectory()) {
// mkdir directory
String dirName = zipEntry.getName();
dirName = dirName.substring(0, dirName.length() - 1);

File f = new File(outFile.getPath() + File.separator
+ dirName);
f.mkdirs();

} else {
FileOutputStream out = null;
// unzip file
File f = new File(outFile.getPath() + File.separator
+ zipEntry.getName());
f.createNewFile();
in = zipFile.getInputStream(zipEntry);
out = new FileOutputStream(f);
int c;
byte[] by = new byte[BUFFEREDSIZE];
while ((c = in.read(by)) != -1) {
out.write(by, 0, c);
}
if(out !=null){
out.close();
}
}

}
} finally {
if (in != null)
in.close();
}
}

用此方法解压一个损坏的文件,会报错,但是捉不到异常,我现在只想实现如果解压过程中碰到文件损坏,能够正确的抓到这个异常,并抛出,给用户一个提示就可以了,求解!
...全文
783 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
dxqrr 2012-08-05
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 的回复:]

没有用到catch的原因是这是一个共用的方法,需要把异常抛出到外部,现在这个问题我己经解决了,但是比较迷惘,解决的办法是我用apache的zipfile来替换原来使用的java原生态zipfile,然后就诡异的可以正确的抛出zipException了,然后我抓到这个异常给用户做交互提示!
[/Quote]
apache的东西果然好用
wineer200 2012-08-01
  • 打赏
  • 举报
回复
没有用到catch的原因是这是一个共用的方法,需要把异常抛出到外部,现在这个问题我己经解决了,但是比较迷惘,解决的办法是我用apache的zipfile来替换原来使用的java原生态zipfile,然后就诡异的可以正确的抛出zipException了,然后我抓到这个异常给用户做交互提示!
业余潜水 2012-08-01
  • 打赏
  • 举报
回复

File outFile = new File(outputDirectory);
if (!outFile.exists()) {
outFile.mkdirs();
}

ZipFile zipFile = null;
try {
zipFile = new ZipFile(zipFilename);
} catch (Exception e) {
throw new Exception("压缩文件已损坏",e);
}
// Enumeration en = zipFile.getEntries();
Enumeration en = zipFile.entries();
ZipEntry zipEntry = null;

dxqrr 2012-07-31
  • 打赏
  • 举报
回复
LZ没有catch啊,控制台什么信息
wineer200 2012-07-31
  • 打赏
  • 举报
回复
试了,拿不到
forgetsam 2012-07-31
  • 打赏
  • 举报
回复
throws Exception 去掉

自己try catch
压缩文件方法方法需要引用zip4j的jar文件 单个文件、多个文件压缩 /** * 使用给定密码压缩指定文件文件夹到指定位置. * * dest可传最终压缩文件存放的绝对路径,也可以传存放目录,也可以传null或者"". * 如果传null或者""则将压缩文件存放在当前目录,即跟源文件同目录,压缩文件名取源文件名,以.zip为后缀; * 如果以路径分隔符(File.separator)结尾,则视为目录,压缩文件名取源文件名,以.zip为后缀,否则视为文件名. * @param src 要压缩的文件文件夹路径 * @param dest 压缩文件存放路径 * @param isCreateDir 是否在压缩文件里创建目录,仅在压缩文件为目录时有效. * 如果为false,将直接压缩目录下文件到压缩文件. * @param passwd 压缩使用的密码 * @return 最终的压缩文件存放的绝对路径,如果为null则说明压缩失败. */ 方法详细见文件! 可选择文件list压缩 /** * 使用给定密码压缩指定文件list * dest可传最终压缩文件存放的绝对路径,也可以传存放目录,也可以传null或者"". * 如果传null或者""则将压缩文件存放在当前目录,即跟源文件同目录,压缩文件名取源文件名,以.zip为后缀; * 如果以路径分隔符(File.separator)结尾,则视为目录,压缩文件名取源文件名,以.zip为后缀,否则视为文件名. * @param src 要压缩的文件集合 * @param dest 压缩文件存放路径 * @param isCreateDir 是否在压缩文件里创建目录,仅在压缩文件为目录时有效. * 如果为false,将直接压缩目录下文件到压缩文件. * @param passwd 压缩使用的密码 * @return 最终的压缩文件存放的绝对路径,如果为null则说明压缩失败. */ 方法详细见文件解压 /** * 使用给定密码解压指定的ZIP压缩文件到指定目录 * * 如果指定目录不存在,可以自动创建,不合法的路径将导致异常被抛出 * @param zipFile 指定的ZIP压缩文件 * @param dest 解压目录 * @param passwd ZIP文件的密码 * @return 解压文件数组 * @throws ZipException 压缩文件损坏或者解压缩失败抛出 */ 方法详细见文件一个简单的demo 欢迎大家指点,一起提升
/** * 使用给定密码压缩指定文件文件夹到指定位置. *

* dest可传最终压缩文件存放的绝对路径,也可以传存放目录,也可以传null或者"".
* 如果传null或者""则将压缩文件存放在当前目录,即跟源文件同目录,压缩文件名取源文件名,以.zip为后缀;
* 如果以路径分隔符(File.separator)结尾,则视为目录,压缩文件名取源文件名,以.zip为后缀,否则视为文件名. * @param src 要压缩的文件文件夹路径 * @param dest 压缩文件存放路径 * @param isCreateDir 是否在压缩文件里创建目录,仅在压缩文件为目录时有效.
* 如果为false,将直接压缩目录下文件到压缩文件. * @param passwd 压缩使用的密码 * @return 最终的压缩文件存放的绝对路径,如果为null则说明压缩失败. */ public static String zip(String src, String dest, boolean isCreateDir, String passwd) { File srcFile = new File(src); ZipParameters parameters = new ZipParameters(); parameters.setCompressionMethod(Zip4jConstants.COMP_DEFLATE); // 压缩方式 parameters.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL); // 压缩级别 if (!StringUtils.isEmpty(passwd)) { parameters.setEncryptFiles(true); parameters.setEncryptionMethod(Zip4jConstants.ENC_METHOD_STANDARD); // 加密方式 parameters.setPassword(passwd.toCharArray()); } try { ZipFile zipFile = new ZipFile(dest); if (srcFile.isDirectory()) { // 如果不创建目录的话,将直接把给定目录下的文件压缩到压缩文件,即没有目录结构 if (!isCreateDir) { File [] subFiles = srcFile.listFiles(); ArrayList temp = new ArrayList(); Collections.addAll(temp, subFiles); zipFile.addFiles(temp, parameters); return dest; } zipFile.addFolder(srcFile, parameters); } else { zipFile.addFile(srcFile, parameters); } return dest; } catch (ZipException e) { e.printStackTrace(); } return null; } /** * 使用给定密码解压指定的ZIP压缩文件到指定目录 *

* 如果指定目录不存在,可以自动创建,不合法的路径将导致异常被抛出 * @param zipFile 指定的ZIP压缩文件 * @param dest 解压目录 * @param passwd ZIP文件的密码 * @return 解压文件数组 为空则解压到当前目录 * @throws ZipException 压缩文件损坏或者解压缩失败抛出 */ public static File [] unzip(File zipFile, String dest, String passwd) throws ZipException { ZipFile zFile = new ZipFile(zipFile); zFile.setFileNameCharset("GBK"); if (!zFile.isValidZipFile()) { throw new ZipException("压缩文件不合法,可能被损坏."); } if(dest ==null || dest.equals("")){ dest = zipFile.getParentFile().getAbsolutePath(); } File destDir = new File(dest); if (destDir.isDirectory() && !destDir.exists()) { destDir.mkdir(); } if (zFile.isEncrypted()) { zFile.setPassword(passwd.toCharArray()); } zFile.extractAll(dest); List headerList = zFile.getFileHeaders(); List extractedFileList = new ArrayList(); for(FileHeader fileHeader : headerList) { if (!fileHeader.isDirectory()) { extractedFileList.add(new File(destDir,fileHeader.getFileName())); } } File [] extractedFiles = new File[extractedFileList.size()]; extractedFileList.toArray(extractedFiles); return extractedFiles; }

DirectX Repair 4.4(64bit) - 系统运行库修复神器 软件简介 DirectX Repair 4.4(64bit)是一款专业系统级修复工具,专注于自动修复和安装Windows系统常用的DirectX和C++运行库。本版本为增强版,不仅支持DirectX修复,还全面支持C++运行库的修复,是解决游戏和软件运行异常的必备工具。 核心功能 一键智能修复:只需点击"检测并修复",即可自动完成检测、下载、修复和注册全过程,无需复杂设置 全面兼容系统:完美支持Windows 7/8/10/11及Vista,自动识别32位/64位系统环境 C++组件自动修复:除DirectX外,还支持C++ 2010/2012/2015-2022等运行库的修复 异步多线程技术:检测、下载、修复任务并行执行,互不干扰,大幅提升修复效率 双模式界面:提供"正常模式"(功能全面)和"简约模式"(高效快速)两种界面选择 适用场景 游戏运行时提示"缺少DirectX组件"或"0xc000007b"错误 软件运行时出现"找不到c++运行库"的报错 系统DLL文件损坏导致程序无法启动 需要快速修复系统运行库异常的情况 特色优势 绿色免安装:无需安装,解压后直接运行,即开即用 智能日志记录:自动记录每次修复过程,便于问题追踪 高级筛选功能:可自定义选择需修复的文件,精准高效 C++自动更新:在修复DirectX的同时,自动检测并更新C++组件 体积优化:较上一版体积减小约5%,运行更加轻便 使用说明 1. 下载解压后,双击运行DirectX Repair主程序 2. 点击"检测并修复"按钮,等待自动完成修复 3. 修复完成后,建议重启系统使更改生效 4. 如问题仍未解决,可尝试在"选项"中启用"同时更新C++"功能

67,542

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧