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都可以正確解壓?。ň唧w原因還不清楚)
本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-04java實現(xiàn)多設(shè)備同時登錄或強(qiáng)制下線
本文主要介紹了java實現(xiàn)多設(shè)備同時登錄或強(qiáng)制下線,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07AsyncHttpClient?ClientStats源碼流程解讀
這篇文章主要為大家介紹了AsyncHttpClient?ClientStats源碼流程解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Java?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-04Java關(guān)鍵字synchronized基本使用詳解
這篇文章主要給大家介紹了關(guān)于Java關(guān)鍵字synchronized基本使用的相關(guān)資料,synchronized可以用來同步靜態(tài)和非靜態(tài)方法,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01Java 關(guān)于時間復(fù)雜度和空間復(fù)雜度的深度刨析
算法復(fù)雜度分為時間復(fù)雜度和空間復(fù)雜度。其作用: 時間復(fù)雜度是度量算法執(zhí)行的時間長短;而空間復(fù)雜度是度量算法所需存儲空間的大小2021-11-11