Java 加密和解密Excel文档

概况

通常来说,对Excel文档进行保护的方法有保护整个工作簿或指定的工作表,以及标记最终状态,设置用户可以编辑区域等。本文将使用Free Spire.XLS for Java来演示如何给Excel工作簿或工作表加密以及移除密码保护。

Jar包获取及导入

在运行代码前,需先将Jar包导入IDEA中。

方式一:在E-iceblue官网上下载Free Spire.XLS for Java产品包,解压后将lib文件夹下的Spire.Xls.jar手动导入IDEA中。导入步骤如下图。

方式二:通过Maven仓库安装导入产品及相关依赖。在IDEA中创建一个Maven项目,然后在pom.xml文件里键入以下代码,最后点击“Import Changes”即可。

       

            com.e-iceblue

            http://repo.e-iceblue.cn/repository/maven-public/

       

   

   

        e-iceblue

        spire.xls.free

        3.9.1

   

代码演示

保护工作簿

Free Spire.XLS for Java提供了work.protect()方法来设置密码保护工作簿,读者只有输入正确密码才能打开工作簿。

import com.spire.xls.*;

public class ProtectWorkbook {

public static void main(String[] args) {

//加载示例文档

Workbook workbook = new Workbook();

workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Sample.xlsx");

//设置密码保护文档

workbook.protect("myexcel123");

//保存结果文档

workbook.saveToFile("output/ProtectWorkbook.xlsx", ExcelVersion.Version2013);

    }

}

效果图:

保护工作表

与保护工作簿相似,我们可以利用sheet.protect()方法来对某个特定的工作表进行加密保护,读者可以打开并查看工作表,但不能对其内容进行编辑操作。

import com.spire.xls.*;

import java.util.EnumSet;

public class ProtectWorksheet {

public static void main(String[] args) {

//加载示例文档

Workbook workbook = new Workbook();

workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Sample.xlsx");

//获取第一个工作表

Worksheet sheet = workbook.getWorksheets().get(0);

//使用密码保护第一个工作表,禁止对其中数据进行更改

sheet.protect("myworksheet123", EnumSet.of(SheetProtectionType.All));

//保存结果文档

workbook.saveToFile("output/ProtectWorksheet.xlsx", ExcelVersion.Version2010);

    }

}

效果图:

取消密码保护工作簿

import com.spire.xls.*;

public class UnprotectWb {

public static void main(String[] args) {

//加载文档

Workbook wb = new Workbook();

wb.setOpenPassword("myexcel123");//源文档密码

wb.loadFromFile("C:\\Users\\Test1\\Desktop\\ProtectWorkbook.xlsx");

//解除密码保护

wb.unProtect();

//保存文档

wb.saveToFile("output/UnprotectWb.xlsx");

wb.dispose();

    }

}

取消密码保护工作表

import com.spire.xls.*;

public class UnprotectWs {

public static void main(String[] args) {

//加载文档

Workbook  wb =new Workbook();

wb.loadFromFile("C:\\Users\\Test1\\Desktop\\ProtectWorksheet.xlsx");

//获取工作表

Worksheet sheet = wb.getWorksheets().get(0);

//解除密码保护(需输入源文档密码)

sheet.unprotect("myworksheet123");

//保存文档

wb.saveToFile("output/UnprotectSheet.xlsx",ExcelVersion.Version2010);

wb.dispose();

    }

}

总结

Free Spire.XLS for Java除了加密工作簿或工作表来保护Excel文档外,还支持设置用户可编辑区域,锁定特定单元格等。有关代码或产品导入问题,可在下方评论或私信。

你可能感兴趣的:(Java 加密和解密Excel文档)