1.前言
上篇文章我有写了java用poi导出excel加密,但excel加密懂点电脑的都知道怎么破解. 所以就衍生出了zip加密。
上篇文章中我都有写出java怎么导出excel的了,这里我就只贴怎么导出excel和怎么压缩的了 解密的这里没有哦!
2.开发思路
1.首先将数据头和数据加入excel ,
2.用文件输入流将excel文件写入,
3.写入成功后拿到文件具体路径,也就是拿到文件
4.用ZipFile生成压缩包文件.
5.用ZipParameters 设置文件的属性
6.创建文件夹并放入文件就好了
7.将压缩成功后这里并不是复制excel文件再生成临时文件目录去压缩的 所以压缩文件生成完成后需要删除原来的excel文件。
8.最后返回生成的压缩文件名称给前端,前端再拿到文件名称去下载(我上篇文章有 上篇文章点击目录第十二个就是的)
以下某些类缺少的可以去我上篇文章拿
链接: https://blog.csdn.net/Ambitiouss/article/details/107366490.
里面包括异常类和文获取件存放地址类
依赖包:
<!-- zip -->
<dependency>
<groupId>net.lingala.zip4j</groupId>
<artifactId>zip4j</artifactId>
<version>1.3.2</version>
</dependency>
package com.test.export;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;
import java.util.Map;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import com.dondown.error.ErrorCode;
import com.dondown.exception.DCPException;
import com.dondown.model.Field;
import com.dondown.util.CheckUtil;
import net.lingala.zip4j.core.ZipFile;
import net.lingala.zip4j.exception.ZipException;
import net.lingala.zip4j.model.ZipParameters;
import net.lingala.zip4j.util.Zip4jConstants;
@Component
public class CustomExport {
private static String zipFilePassword = "123456";
/**
* @param zipPath
* 创建zip文件的 文件路径+zip名称
* @param folderPath
* 待压缩文件夹或者待压缩文件
*/
private static String zipFile(String zipPath,String fileName, File folderPath) throws ZipException {
// 切割.后缀名 不然文件下载后缀名为xlszip 虽然也是zip文件,但会让人感觉很奇怪
// java中的.需要转义 \\. 才是.
String []fastFileName = null;
if (!CheckUtil.isNull(fileName)) {
fastFileName = fileName.split("\\.");
}
fileName = fastFileName[0];
ZipFile zipFile = new ZipFile(zipPath+"\\"+fileName+".zip");
ZipParameters parameters = new ZipParameters(); // 设置zip包的一些参数集合
parameters.setEncryptFiles(true); // 是否设置密码(此处设置为:是)
parameters.setCompressionMethod(Zip4jConstants.COMP_DEFLATE); // 压缩方式(默认值)
parameters.setCompressionLevel(Zip4jConstants.DEFLATE_LEVEL_NORMAL); // 普通级别(参数很多)
parameters.setEncryptionMethod(Zip4jConstants.ENC_METHOD_STANDARD); // 加密级别
parameters.setPassword(zipFilePassword); // 压缩包密码
if (folderPath.isDirectory()) {
zipFile.createZipFileFromFolder(folderPath, parameters, false, -1L);
} else {
zipFile.createZipFile(folderPath, parameters);
}
return zipFile.getFile().getName();
}
/**
* 压缩完成后删除excel文件
*/
private static boolean deleteFile(String sPath) {
boolean flag = false;
File file = new File(sPath);
// 路径为文件且不为空则进行删除
if (file.isFile() && file.exists()) {
file.delete();
flag = true;
}
return flag;
}
}
4.效果
5.结尾了
感谢大家, 点个赞啊。
6.最最后
下篇文章打算写Linux, 以前会一点 现在都忘记了,学几天再来写 哈哈哈 拜拜… 再会哦