Java中解壓縮文件的方法詳解(通用)
如何實(shí)現(xiàn)一個(gè)上傳壓縮包,然后將壓縮包進(jìn)行解壓?
下面我們就來(lái)實(shí)現(xiàn)一下這個(gè)代碼。
最終實(shí)現(xiàn)的效果:
上傳一個(gè)壓縮包文件,會(huì)將壓縮包文件下載到本地,然后再將壓縮包解壓到同目錄下的extracted文件夾下。

這是壓縮包內(nèi)的文件,三張圖片

一、使用的技術(shù)
使用的是Java自帶的java.util.zip.ZipFile包。
java.util.zip.ZipFile 是 Java 中用于處理 ZIP 文件的類(lèi)。它提供了讀取 ZIP 文件內(nèi)容的功能,允許你以編程方式從 ZIP 文件中提取文件和目錄結(jié)構(gòu),以及讀取其中的數(shù)據(jù)。
下面是一些 ZipFile 類(lèi)的主要特性和用法:
讀取 ZIP 文件內(nèi)容:
ZipFile允許你打開(kāi)一個(gè) ZIP 文件,并從中讀取內(nèi)容。你可以通過(guò)提供 ZIP 文件的路徑或者File對(duì)象來(lái)創(chuàng)建一個(gè)ZipFile實(shí)例。訪問(wèn) ZIP 文件中的條目(entries): 一旦你打開(kāi)了一個(gè) ZIP 文件,你可以通過(guò)
entries()方法獲取 ZIP 文件中的所有條目。每個(gè)條目代表 ZIP 文件中的一個(gè)文件或目錄。提取文件內(nèi)容: 通過(guò)
getInputStream()方法,你可以從 ZIP 文件中提取特定文件的內(nèi)容。這個(gè)方法返回一個(gè)InputStream對(duì)象,你可以使用它來(lái)讀取文件的數(shù)據(jù)。關(guān)閉 ZIP 文件: 使用
close()方法關(guān)閉ZipFile實(shí)例,釋放相關(guān)資源。
二、實(shí)際用法
實(shí)際使用的時(shí)候是從前端上傳壓縮包文件,然后后端接收。(具體參考后文Contrller中的完整代碼邏輯)
1、上傳的一般都是MultipartFile類(lèi)型,需要先將MultipartFile類(lèi)型轉(zhuǎn)為File類(lèi)型,使用FileUtils.copyInputStreamToFile這個(gè)方法。
2、轉(zhuǎn)換為File類(lèi)型時(shí)就需要先將文件存到本地,所以在這里指定了一個(gè)壓縮包的文件路徑File fileTemp = new File("D:\\unzipTest\\Test.zip");
3、使用getAbsolutePath方法來(lái)獲取這個(gè)路徑,將壓縮包的本地路徑傳給fileUncompressing文件解壓縮方法即可完成解壓。
4、在文件解壓縮方法中,會(huì)將文件解壓到D:\\unzipTest\\extracted這個(gè)目錄下,可以自行修改,也可以作為一個(gè)參數(shù)傳進(jìn)去。
我這里解壓縮的時(shí)候獲取了某個(gè)固定文件類(lèi)型的文件路徑集合,如果需要在解壓縮的時(shí)候做邏輯處理,可以參考。如果只是單純的解壓縮,可以把這個(gè)邏輯刪掉。
//要下載到的本地臨時(shí)文件路徑
File fileTemp = new File("D:\\unzipTest\\Test.zip");
File parentFolder = fileTemp.getParentFile();
//如果父文件夾(unzipTest)不存在則創(chuàng)建
if(!parentFolder.exists()){
//創(chuàng)建父文件夾及其所有上級(jí)文件夾
parentFolder.mkdir();
}
//MultipartFile轉(zhuǎn)File
org.apache.commons.io.FileUtils.copyInputStreamToFile(multipartFile.getInputStream(), fileTemp);
//壓縮包文件路徑
String zipFilePath = fileTemp.getAbsolutePath();
fileUncompressing(zipFilePath);
三、文件解壓縮方法(通用)
/**
* 文件解壓縮
* @return
*/
public static List<String> fileUncompressing(String zipFilePath){
String targetFolder = "D:\\unzipTest\\extracted";
//文件名后綴
String ncLastName=".nc";
List<String> pathList=new ArrayList<>();
try {
// 創(chuàng)建目標(biāo)文件夾
File targetDir = new File(targetFolder);
targetDir.mkdirs();
// 打開(kāi)壓縮文件
// ZipFile zipFile = new ZipFile(zipFilePath);
ZipFile zipFile = new ZipFile(zipFilePath, Charset.forName("gbk"));
// 遍歷壓縮文件中的所有條目
Enumeration<? extends ZipEntry> entries = zipFile.entries();
while (entries.hasMoreElements()) {
ZipEntry entry = entries.nextElement();
// 解壓縮條目到目標(biāo)文件夾
String entryName = entry.getName();
entryName = new String(entryName.getBytes(Charset.forName("gbk")));
File entryFile = new File(targetDir, entryName);
if (entry.isDirectory()) {
entryFile.mkdirs();
} else {
entryFile.getParentFile().mkdirs();
InputStream inputStream = zipFile.getInputStream(entry);
OutputStream outputStream = new FileOutputStream(entryFile);
byte[] buffer = new byte[1024];
int length;
while ((length = inputStream.read(buffer)) > 0) {
outputStream.write(buffer, 0, length);
}
outputStream.close();
inputStream.close();
}
//判斷文件是否是.nc結(jié)尾
if (entryName.endsWith(ncLastName)) {
// 拼接路徑
Path path = Paths.get(targetFolder, entryName);
pathList.add(path.toString());
}
}
// 關(guān)閉壓縮文件
zipFile.close();
// log.info("文件讀取完成");
System.out.println("文件讀取完成");
} catch (ZipException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return pathList;
}
四、完整代碼邏輯
@RestController
@RequestMapping("/practice")
public class PracticeController extends BaseController
{
@PostMapping("/list")
public TableDataInfo list(MultipartFile multipartFile) throws IOException {
//要下載到的本地臨時(shí)文件路徑
File fileTemp = new File("D:\\unzipTest\\Test.zip");
File parentFolder = fileTemp.getParentFile();
//如果父文件夾(unzipTest)不存在則創(chuàng)建
if(!parentFolder.exists()){
//創(chuàng)建父文件夾及其所有上級(jí)文件夾
parentFolder.mkdir();
}
//MultipartFile轉(zhuǎn)File
org.apache.commons.io.FileUtils.copyInputStreamToFile(multipartFile.getInputStream(), fileTemp);
//壓縮包文件路徑
String zipFilePath = fileTemp.getAbsolutePath();
fileUncompressing(zipFilePath);
startPage();
List<StudentScores> list = new ArrayList<>();
return getDataTable(list);
}
/**
* 文件解壓縮
* @return
*/
public static List<String> fileUncompressing(String zipFilePath){
// String zipFilePath = "D:\\unzipTest\\ERA5.zip";
String targetFolder = "D:\\unzipTest\\extracted";
//文件名后綴
String ncLastName=".nc";
List<String> pathList=new ArrayList<>();
try {
// 創(chuàng)建目標(biāo)文件夾
File targetDir = new File(targetFolder);
targetDir.mkdirs();
// 打開(kāi)壓縮文件
// ZipFile zipFile = new ZipFile(zipFilePath);
ZipFile zipFile = new ZipFile(zipFilePath, Charset.forName("gbk"));
// 遍歷壓縮文件中的所有條目
Enumeration<? extends ZipEntry> entries = zipFile.entries();
while (entries.hasMoreElements()) {
ZipEntry entry = entries.nextElement();
// 解壓縮條目到目標(biāo)文件夾
String entryName = entry.getName();
entryName = new String(entryName.getBytes(Charset.forName("gbk")));
File entryFile = new File(targetDir, entryName);
if (entry.isDirectory()) {
entryFile.mkdirs();
} else {
entryFile.getParentFile().mkdirs();
InputStream inputStream = zipFile.getInputStream(entry);
OutputStream outputStream = new FileOutputStream(entryFile);
byte[] buffer = new byte[1024];
int length;
while ((length = inputStream.read(buffer)) > 0) {
outputStream.write(buffer, 0, length);
}
outputStream.close();
inputStream.close();
}
//判斷文件是否是.nc結(jié)尾
if (entryName.endsWith(ncLastName)) {
// 拼接路徑
Path path = Paths.get(targetFolder, entryName);
pathList.add(path.toString());
}
}
// 關(guān)閉壓縮文件
zipFile.close();
// log.info("文件讀取完成");
System.out.println("文件讀取完成");
} catch (ZipException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return pathList;
}
}總結(jié)
到此這篇關(guān)于Java中解壓縮文件的方法詳解的文章就介紹到這了,更多相關(guān)Java解壓縮文件方法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解MyBatis批量插入數(shù)據(jù)Mapper配置文件的寫(xiě)法
本篇文章主要介紹了詳解MyBatis批量插入數(shù)據(jù)Mapper文件的寫(xiě)法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-04-04
圖解Java中歸并排序算法的原理與實(shí)現(xiàn)
歸并排序是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個(gè)非常典型的應(yīng)用。本文將通過(guò)圖片詳解插入排序的原理及實(shí)現(xiàn),需要的可以參考一下2022-08-08
JavaWeb response完成重定向?qū)崿F(xiàn)過(guò)程詳解
這篇文章主要介紹了JavaWeb response完成重定向?qū)崿F(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02
判斷二叉樹(shù)是否為完全二叉樹(shù)的實(shí)例
這篇文章主要介紹了判斷二叉樹(shù)是否為完全二叉樹(shù)的實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-05-05
Java幾個(gè)實(shí)例帶你進(jìn)階升華上篇
與其明天開(kāi)始,不如現(xiàn)在行動(dòng),本文為你帶來(lái)幾個(gè)Java書(shū)寫(xiě)的實(shí)際案例,對(duì)鞏固編程的基礎(chǔ)能力很有幫助,快來(lái)一起往下看看吧2022-03-03
Java的Hibernate框架中的組合映射學(xué)習(xí)教程
組合映射即是指主對(duì)象和子對(duì)象關(guān)聯(lián)且擁有相同的生命周期的映射關(guān)系,這里我們將舉一些數(shù)據(jù)操作的實(shí)例,來(lái)講解Java的Hibernate框架中的組合映射學(xué)習(xí)教程2016-07-07
java 數(shù)據(jù)結(jié)構(gòu)單鏈表的實(shí)現(xiàn)
這篇文章主要介紹了java 數(shù)據(jù)結(jié)構(gòu)單鏈表的實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-07-07
部署springboot打包不打包配置文件,配置文件為外部配置文件使用詳解
在Spring Boot項(xiàng)目中,將配置文件排除在jar包之外,通過(guò)外部配置文件來(lái)管理不同環(huán)境的配置,可以實(shí)現(xiàn)靈活的配置管理,在pom.xml文件中添加相關(guān)配置,打包時(shí)忽略指定文件,運(yùn)行時(shí)在jar包同級(jí)目錄下創(chuàng)建config文件夾,將配置文件放入其中即可2025-02-02
SpringBoot實(shí)現(xiàn)RabbitMQ三種使用方式
本文主要介紹了SpringBoot實(shí)現(xiàn)RabbitMQ三種使用方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07

