Java excel导出压缩zip并加密(拿起即用,有用请点赞,不做白嫖怪!)

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, 以前会一点 现在都忘记了,学几天再来写 哈哈哈 拜拜… 再会哦

借鉴博客链接: https://my.oschina.net/u/4297712/blog/3559708.

压缩文件方法 该方法需要引用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 欢迎大家指点,一起提升
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值