文章目录

  • 1.前言
  • 2.开发思路
  • 以下某些类缺少的可以去我上篇文章拿
  • 4.效果
  • 5.结尾了
  • 6.最最后


1.前言

上篇文章我有写了java用poi导出excel加密,但excel加密懂点电脑的都知道怎么. 所以就衍生出了zip加密。
上篇文章中我都有写出java怎么导出excel的了,这里我就只贴怎么导出excel和怎么压缩的了 解密的这里没有哦!

2.开发思路

1.首先将数据头和数据加入excel ,
2.用文件输入流将excel文件写入,
3.写入成功后拿到文件具体路径,也就是拿到文件
4.用ZipFile生成压缩包文件.
5.用ZipParameters 设置文件的属性
6.创建文件夹并放入文件就好了
7.将压缩成功后这里并不是复制excel文件再生成临时文件目录去压缩的 所以压缩文件生成完成后需要删除原来的excel文件。
8.最后返回生成的压缩文件名称给前端,前端再拿到文件名称去下载(我上篇文章有 上篇文章点击目录第十二个就是的)


里面包括异常类和文获取件存放地址类

依赖包:

<!-- 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.效果

excel java 密码 java导出excel加密_java

5.结尾了

感谢大家, 点个赞啊。

6.最最后

下篇文章打算写Linux, 以前会一点 现在都忘记了,学几天再来写 哈哈哈 拜拜… 再会哦