概况
通常来说,对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”即可。
<repositories>
<repository>
<id>com.e-iceblue</id>
<url>http://repo.e-iceblue.cn/repository/maven-public/</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>e-iceblue</groupId>
<artifactId>spire.xls.free</artifactId>
<version>3.9.1</version>
</dependency>
</dependencies>
代码演示
保护工作簿
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文档外,还支持设置用户可编辑区域,锁定特定单元格等。有关代码或产品导入问题,可在下方评论或私信。