java 解壓與壓縮文件夾的實例詳解
java 解壓與壓縮文件夾的實例詳解
注意:JDK7支持設(shè)置編碼設(shè)置編碼格式 zipFile,zipInputStream,zipOutputStream都增加了編碼格式,如果是jdk1.6需要其他的包輔助
下面為自帶jdk壓縮文件夾代碼:
public void dozip(String srcfile, String zipfile) throws IOException {
String temp = "";
File src = new File(srcfile);
File zipFile=new File(zipfile);
//判斷要壓縮的文件存不存在
if (!src.exists()) {
System.err.println("要壓縮的文件不存在!");
System.exit(1);
}
//如果說壓縮路徑不存在,則創(chuàng)建
if (!zipFile.getParentFile().exists()) {
zipFile.getParentFile().mkdirs();
// System.out.println("創(chuàng)建ok");
}
// 封裝壓縮的路徑
BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(zipfile));
//這里可以加入校驗
//CheckedOutputStream cos = new CheckedOutputStream(bos,new CRC32());
//還可以設(shè)置壓縮格式,默認(rèn)UTF-8
Charset charset = Charset.forName("GBK");
ZipOutputStream zos = new ZipOutputStream(bos,charset);
zip(src, zos, temp);
//關(guān)閉流
zos.flush();
zos.close();
System.out.println("壓縮完成!");
System.out.println("壓縮文件的位置是:" + zipfile);
// System.out.println("檢驗和:"+cos.getChecksum().getValue());
}
private void zip(File file, ZipOutputStream zos, String temp)
throws IOException {
// 如果不加"/"將會作為文件處理,空文件夾不需要讀寫操作
if (file.isDirectory()) {
String str = temp + file.getName() + "/";
zos.putNextEntry(new ZipEntry(str));
File[] files = file.listFiles();
for (File file2 : files) {
zip(file2, zos, str);
}
} else {
// System.out.println("當(dāng)前文件的父路徑:"+temp);
ZipFile(file, zos, temp);
}
}
private void ZipFile(File srcfile, ZipOutputStream zos, String temp)
throws IOException {
// 默認(rèn)的等級壓縮-1
// zos.setLevel(xxx);
// 封裝待壓縮文件
BufferedInputStream bis = new BufferedInputStream(new FileInputStream(
srcfile));
zos.putNextEntry(new ZipEntry(temp + srcfile.getName()));
byte buf[] = new byte[1024];
int len;
while ((len = bis.read(buf)) != -1) {
zos.write(buf, 0, len);
}
//按標(biāo)準(zhǔn)需要關(guān)閉當(dāng)前條目,不寫也行
zos.closeEntry();
bis.close();
}
下面為解壓:
這里先說一下好壓的解壓規(guī)則:
1.如果解壓到與壓縮文件同名的文件夾,則直接解壓
如果自定義了其他文件夾xxx,則先創(chuàng)建xxx,再放入解壓后的文件夾
2.好壓壓縮的時候,是采用GBK格式的,所以在解壓的時候,為了統(tǒng)一,采用GBK解壓另外再說一下WINRAR,因為RAR壓縮是申請了專利(商業(yè)軟件),所以RAR壓縮算法是不公開的,但是解壓算法是有的,其壓縮默認(rèn)也是GBK格式的;
經(jīng)過測試,發(fā)現(xiàn),不管壓縮的時候采用UTF-8還是GBK,解壓的時候用GBK都可以正確解壓!(具體原因還不清楚)
本java程序是直接解壓到文件夾的,默認(rèn)解壓到與壓縮文件同路徑
如果解壓編碼有問題,則報錯:java.lang.IllegalArgumentException: MALFORMED
如果壓縮文件有密碼:則報錯:java.util.zip.ZipException: encrypted ZIP entry not supporte
//方法1:
public void unZip(String zipfile) throws IOException {
//檢查是否是zip文件,并判斷文件是否存在
checkFileName(zipfile);
long startTime = System.currentTimeMillis();
File zfile=new File(zipfile);
//獲取待解壓文件的父路徑
String Parent=zfile.getParent()+"/";
FileInputStream fis=new FileInputStream(zfile);
Charset charset = Charset.forName("GBK");//默認(rèn)UTF-8
// CheckedInputStream cis = new CheckedInputStream(fis,new CRC32());
ZipInputStream zis = new ZipInputStream(fis,charset);// 輸入源zip路徑
ZipEntry entry=null;
BufferedOutputStream bos=null;
while ((entry=zis.getNextEntry())!=null) {
if (entry.isDirectory()) {
File filePath=new File(Parent+entry.getName());
//如果目錄不存在,則創(chuàng)建
if (!filePath.exists()) {
filePath.mkdirs();
}
}else{
FileOutputStream fos=new FileOutputStream(Parent+entry.getName());
bos=new BufferedOutputStream(fos);
byte buf[] = new byte[1024];
int len;
while ((len = zis.read(buf)) != -1) {
bos.write(buf, 0, len);
}
zis.closeEntry();
//關(guān)閉的時候會刷新
bos.close();
}
}
zis.close();
long endTime = System.currentTimeMillis();
System.out.println("解壓完成!所需時間為:"+(endTime-startTime)+"ms");
// System.out.println("校驗和:"+cis.getChecksum().getValue());
}
private void checkFileName(String name) {
//文件是否存在
if (!new File(name).exists()) {
System.err.println("要解壓的文件不存在!");
System.exit(1);
}
// 判斷是否是zip文件
int index = name.lastIndexOf(".");
String str=name.substring(index+1);
if (!"zip".equalsIgnoreCase(str)) {
System.err.println("不是zip文件,無法解壓!");
System.exit(1);
}
}
方法2:
利用zipFile解壓,方法跟ZipInputStream類似,都是連續(xù)取到Entry,然后再用Entry判斷,聽說zipFile內(nèi)建了緩沖流,所以對于同一個文件解壓多次效率比ZipInputStream高些
public void dozip(String zipfile) throws IOException {
checkFileName(zipfile);
long startTime = System.currentTimeMillis();
// 獲取待解壓文件的父路徑
File zfile = new File(zipfile);
String Parent = zfile.getParent() + "/";
// 設(shè)置,默認(rèn)是UTF-8
Charset charset = Charset.forName("GBK");
ZipFile zip = new ZipFile(zipfile, charset);
ZipEntry entry = null;
//封裝解壓后的路徑
BufferedOutputStream bos=null;
//封裝待解壓文件路徑
BufferedInputStream bis=null;
Enumeration<ZipEntry> enums = (Enumeration<ZipEntry>) zip.entries();
while (enums.hasMoreElements()) {
entry = enums.nextElement();
if (entry.isDirectory()) {
File filePath = new File(Parent + entry.getName());
// 如果目錄不存在,則創(chuàng)建
if (!filePath.exists()) {
filePath.mkdirs();
}
}else{
bos=new BufferedOutputStream(new FileOutputStream(Parent + entry.getName()));
//獲取條目流
bis =new BufferedInputStream(zip.getInputStream(entry));
byte buf[] = new byte[1024];
int len;
while ((len = bis.read(buf)) != -1) {
bos.write(buf, 0, len);
}
bos.close();
}
}
bis.close();
zip.close();
System.out.println("解壓后的路徑是:"+Parent);
long endTime = System.currentTimeMillis();
System.out.println("解壓成功,所需時間為:"+(endTime-startTime)+"ms");
}
private void checkFileName(String name) {
// 文件是否存在
if (!new File(name).exists()) {
System.err.println("要解壓的文件不存在!");
System.exit(1);
}
// 判斷是否是zip文件
int index = name.lastIndexOf(".");
String str = name.substring(index + 1);
if (!"zip".equalsIgnoreCase(str)) {
System.err.println("不是zip文件,無法解壓!");
System.exit(1);
}
}
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
SpringCloud?Ribbon負(fù)載均衡流程分析
在Eureka注冊中心中我們在添加完@LoadBalanced注解,即可實現(xiàn)負(fù)載均衡功能,現(xiàn)在一起探索一下負(fù)載均衡的原理(Ribbon),感興趣的朋友一起看看吧2024-03-03
解決Spring調(diào)用Feign報錯:java.io.IOException:Incomplete output
這篇文章主要介紹了解決Spring調(diào)用Feign報錯:java.io.IOException:Incomplete output stream問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-04-04
java實現(xiàn)多設(shè)備同時登錄或強(qiáng)制下線
本文主要介紹了java實現(xiàn)多設(shè)備同時登錄或強(qiáng)制下線,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
AsyncHttpClient?ClientStats源碼流程解讀
這篇文章主要為大家介紹了AsyncHttpClient?ClientStats源碼流程解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
Java?InheritableThreadLocal使用示例詳解
InheritableThreadLocal繼承了ThreadLocal,此類擴(kuò)展了ThreadLocal以提供從父線程到子線程的值的繼承:當(dāng)創(chuàng)建子線程時,子線程接收父線程具有的所有可繼承線程局部變量的初始值。?通常子線程的值與父線程的值是一致的2022-09-09
淺談SpringCloud的微服務(wù)架構(gòu)組件
這篇文章主要介紹了淺談SpringCloud的微服務(wù)架構(gòu)組件,Spring Cloud根據(jù)分布式服務(wù)協(xié)調(diào)治理的需求成立了許多子項目,每個項目通過特定的組件去實現(xiàn),需要的朋友可以參考下2023-04-04
Java關(guān)鍵字synchronized基本使用詳解
這篇文章主要給大家介紹了關(guān)于Java關(guān)鍵字synchronized基本使用的相關(guān)資料,synchronized可以用來同步靜態(tài)和非靜態(tài)方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01
Java 關(guān)于時間復(fù)雜度和空間復(fù)雜度的深度刨析
算法復(fù)雜度分為時間復(fù)雜度和空間復(fù)雜度。其作用: 時間復(fù)雜度是度量算法執(zhí)行的時間長短;而空間復(fù)雜度是度量算法所需存儲空間的大小2021-11-11

