概况
通常来说,对Excel文档进行保护的方法有保护整个工作簿或指定的工作表,以及标记最终状态,设置用户可以编辑区域等。本文将使用
Jar包获取及导入
在运行代码前,需先将Jar包导入IDEA中。
方式一:在E-iceblue官网上下载Free Spire.XLS for Java产品包,解压后将lib文件夹下的Spire.Xls.jar手动导入IDEA中。导入步骤如下图。
方式二:通过
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()方法来设置密码保护工作簿,读者只有输入正确密码才能打开工作簿。
importcom.spire.xls.*;
public classProtectWorkbook {
public static voidmain(String[] args) {
//加载示例文档
Workbook workbook = newWorkbook();
workbook.loadFromFile("C:\\Users\\Test1\\Desktop\\Sample.xlsx");
//设置密码保护文档
workbook.protect("myexcel123");
//保存结果文档
workbook.saveToFile("output/ProtectWorkbook.xlsx", ExcelVersion.Version2013);
}
}
效果图:
保护工作表
与保护工作簿相似,我们可以利用sheet.protect()方法来对某个特定的工作表进行加密保护,读者可以打开并查看工作表,但不能对其内容进行编辑操作。
importcom.spire.xls.*;
importjava.util.EnumSet;
public classProtectWorksheet {
public static voidmain(String[] args) {
//加载示例文档
Workbook workbook = newWorkbook();
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 classUnprotectWb {
public static voidmain(String[] args) {
//加载文档
Workbook wb = newWorkbook();
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 classUnprotectWs {
public static voidmain(String[] args) {
//加载文档
Workbook wb =newWorkbook();
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文档外,还支持设置用户可编辑区域,锁定特定单元格等。有关代码或产品导入问题,可在下方评论或私信。