java使用poi对excel文件的加密解密

1、首先pom文件引入poi包,如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>poi</artifactId>
    <version>1.0-SNAPSHOT</version>
<dependencies>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>4.1.0</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>4.1.0</version>
    </dependency>
</dependencies>

</project>

 

2、具体加解密代码如下

import java.io.*;
import java.security.GeneralSecurityException;

import org.apache.poi.hssf.record.crypto.Biff8EncryptionKey;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.openxml4j.opc.PackageAccess;
import org.apache.poi.poifs.crypt.*;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.util.LittleEndianInput;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelUtil {
    public static void main(String[] args) throws Exception {
        encryptExcl("G:\\学生.xls", "123456");//加密
//        encryptExcl("G:\\学生2.xlsx", "test");//加密
//        decryptExcel_xlsx("G:\\学生2.xlsx", "test");//解密xlsx
//        decryptExcel_xls("G:\\学生.xls", "123456");//解密xls


    }

    /**
     *解密xls
     * @param FILE 文件名
     * @param password 密码
     */
    public static void decryptExcel_xls(String FILE, String password){
        try{
            POIFSFileSystem pfs = new POIFSFileSystem(new FileInputStream(FILE));
            //解密,这个密码不是指保护工作表和工作博密码,而是打开文件密码
            Biff8EncryptionKey.setCurrentUserPassword(password);
            HSSFWorkbook wb = new HSSFWorkbook(pfs);
            //读取测试
            HSSFSheet sheet = wb.getSheetAt(0);
            HSSFRow row = sheet.getRow(0);
            HSSFCell cell = row.getCell(0);
            System.out.println(cell.getStringCellValue());
            wb.close();
        }catch(Exception e){
            e.printStackTrace();
        }finally {
        }
    }
    /**
     * 解密xlsx
     * @param FILE 文件名
     * @param password 密码
     * @throws Exception
     */
    public static void decryptExcel_xlsx(String FILE, String password) throws Exception{
        Workbook wb = null;
        FileInputStream in = null;
        try {
            in = new FileInputStream(FILE);
            POIFSFileSystem poifsFileSystem = new POIFSFileSystem(in);
            EncryptionInfo encInfo = new EncryptionInfo(poifsFileSystem);
            Decryptor decryptor = Decryptor.getInstance(encInfo);
            decryptor.verifyPassword(password);
            wb = new XSSFWorkbook(decryptor.getDataStream(poifsFileSystem));
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            in.close();
        }
        System.out.println("=================================");
        System.out.println("Number of Sheets:" + wb.getNumberOfSheets());
        System.out.println("Sheet1's name:" + wb.getSheetName(0));
        System.out.println();
    }

    /**
     * 加密Excl
     * @param FILE
     * @param password
     * @throws IOException
     * @throws InvalidFormatException
     * @throws GeneralSecurityException
     */
    public static void encryptExcl(String FILE, String password) throws IOException, InvalidFormatException, GeneralSecurityException {
        if (FILE.toLowerCase().endsWith("xlsx")) {
            System.out.println("=====加密 xlsx===="+FILE);
            // 设置密 码 保 护 ·
            POIFSFileSystem fs = new POIFSFileSystem();
            EncryptionInfo info = new EncryptionInfo(EncryptionMode.standard);
            Encryptor enc = info.getEncryptor();
            //设置密码
            enc.confirmPassword(password);
            //加密文件
            OPCPackage opc = OPCPackage.open(new File(FILE), PackageAccess.READ_WRITE);
            OutputStream os = enc.getDataStream(fs);
            opc.save(os);
            opc.close();
            // 这一步特别注意,导出之前一定要先关闭加密文件流,不然导出文件会损坏而无法打开
            os.close();
            //把加密后的文件写回到流
            FileOutputStream fos = new FileOutputStream(FILE);
            fs.writeFilesystem(fos);
            fos.close();
        } else {
            System.out.println("=====加密 xls===="+FILE);
            POIFSFileSystem poif = new POIFSFileSystem(new FileInputStream(FILE));
            HSSFWorkbook wb = new HSSFWorkbook(poif);
            // 设置密 码 保 护 ·
            Biff8EncryptionKey.setCurrentUserPassword(password);
            wb.writeProtectWorkbook(Biff8EncryptionKey.getCurrentUserPassword(), "管理员");
            wb.unwriteProtectWorkbook();
            // 写入excel文件
            FileOutputStream fileOut = new FileOutputStream(FILE);
            wb.write(fileOut);
            fileOut.close();
        }

        System.out.println("over");

    }


}

 

Java使用POI库可以实现对Excel文件的读取操作。具体的步骤如下: 1. 引用POI库。在Java项目中引入POI相关的jar包。 2. 创建文件输入流。使用FileInputStream类创建一个输入流对象,并指定要读取的Excel文件路径。 3. 创建工作簿对象。使用HSSFWorkbook类创建一个工作簿对象,将输入流作为参数传入。 4. 获取工作表。使用getSheetAt方法获取指定的工作表,可以通过工作表的索引或名称进行获取。 5. 获取行。使用getRow方法获取指定行的对象,行号作为参数传递给该方法。 6. 获取单元格。使用getCell方法获取指定单元格的对象,行号和列号作为参数传递给该方法。 7. 获取单元格的值。使用getStringCellValue方法获取单元格的值,将其赋给一个字符串变量。 8. 输出结果。使用System.out.println方法将获取到的数据打印出来。 需要注意的是,在读取Excel文件时可能会出现FileNotFoundException和IOException异常,需要进行异常处理。同时,在读取完成后,需要关闭输入流。 下面是一个示例代码,用于演示Java使用POI读取Excel文件: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class ExcelReader { public static void poiRead() { FileInputStream xlsStream = null; try { // 创建文件输入流 xlsStream = new FileInputStream(new File("C:\\Users\\itour\\Desktop\\poiTest.xls")); // 创建工作簿对象 HSSFWorkbook hssfWorkbook = new HSSFWorkbook(xlsStream); // 获取工作表 HSSFSheet sheetAt = hssfWorkbook.getSheetAt(0); // 获取行 HSSFRow row = sheetAt.getRow(0); // 获取单元格 HSSFCell cell = row.getCell(0); // 获取单元格的值 String cellValue = cell.getStringCellValue(); System.out.println("获取到的数据是:" + cellValue); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (xlsStream != null) { try { xlsStream.close(); } catch (IOException e) { e.printStackTrace(); } } } } } ``` 以上代码演示了如何使用POI库读取Excel文件中第一个工作表的第一个单元格的值。你可以根据自己的需求进行修改和扩展。
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值