温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java如何加密/解密Excel

发布时间:2021-11-20 13:42:18 来源:亿速云 阅读:347 作者:小新 栏目:编程语言

小编给大家分享一下Java如何加密/解密Excel,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

工具

工具:Free Spire.XLS for Java (免费版)

注1: 可通过官网下载jar包,并解压将lib文件夹中的jar文件导入java程序;或者通过maven仓库下载安装导入。

Jar导入效果:

Java如何加密/解密Excel

注2:这里设置工作表保护时,可支持多种不同类型的保护(如下图),本文示例以选择其中一种为例。

Java如何加密/解密Excel

Java代码示例

【示例1】加密工作簿

import com.spire.xls.*;
 
 public class ProtectWb {
     public static void main(String[] args) {
         //加载测试文档
         Workbook wb = new Workbook();
         wb.loadFromFile("sample.xlsx");
 
         //使用密码加密工作簿
         wb.protect("123456");
 
         //保存文档
         wb.saveToFile("ProtectWorkbook.xlsx", ExcelVersion.Version2010);
         wb.dispose();
     }
 }

工作簿加密结果:

Java如何加密/解密Excel

【示例2】解密工作簿

import com.spire.xls.*;
 
 public class UnprotectWb {
     public static void main(String[] args) {
         //加载文档
         Workbook wb = new Workbook();
         wb.setOpenPassword("123456");//源文档密码
         wb.loadFromFile("ProtectWorkbook.xlsx");
 
         //解除密码保护
         wb.unProtect();
 
         //保存文档
         wb.saveToFile("UnprotectWb.xlsx");
         wb.dispose();
     }
 }

运行程序,生成的工作簿文件将不再有密码保护。

【示例3】加密工作表

import com.spire.xls.*;
 
 import java.util.EnumSet;
 
 public class ProtectSheet {
     public static void main(String[] args) {
         //加载测试文档
         Workbook wb = new Workbook();
         wb.loadFromFile("sample.xlsx");
 
         //获取第一个工作表
         Worksheet sheet = wb.getWorksheets().get(0);
 
         //使用密码加密保护
         sheet.protect("654321", EnumSet.of(SheetProtectionType.All));
 
         //保存文档
         wb.saveToFile("ProtectWorksheet.xlsx", ExcelVersion.Version2010);
         wb.dispose();
     }
 }

工作表加密结果:

Java如何加密/解密Excel

【示例4】加密工作表指定数据范围

import com.spire.xls.*;
 
 import java.util.EnumSet;
 
 public class ProtectRange {
     public static void main(String[] args) {
         //加载测试文档
         Workbook wb = new Workbook();
         wb.loadFromFile("sample.xlsx");
 
         //获取第一个工作表
         Worksheet sheet = wb.getWorksheets().get(0);
 
         //密码加密工作表
         sheet.protect("123654", EnumSet.of(SheetProtectionType.All));
         //指定可编辑的区域
         sheet.addAllowEditRange("AllowEdit",sheet.getCellRange(3,1,11,8));
 
         //保存文档
         wb.saveToFile("ProtectRange.xlsx", ExcelVersion.Version2010);
         wb.dispose();
     }
 }

指定区域加密结果:

Java如何加密/解密Excel

【示例5】设置工作表公式隐藏

import com.spire.xls.*;
 
 import java.util.EnumSet;
 
 public class ProtectAndHideFormula {
     public static void main(String[] args) {
         //加载文档
         Workbook  wb = new Workbook();
         wb.loadFromFile("sample.xlsx");
 
         //获取工作表
         Worksheet sheet = wb.getWorksheets().get(0);
 
         //设置加密
         sheet.protect("123", EnumSet.of(SheetProtectionType.All));
         //隐藏公式
         sheet.getAllocatedRange().isFormulaHidden(true);
 
         //保存文档
         wb.saveToFile("HideFormula.xlsx",FileFormat.Version2010);
         wb.dispose();
     }
 }

设置公式隐藏结果:

Java如何加密/解密Excel

【示例6】解密Excel工作表

import com.spire.xls.*;
 
 public class UnprotectSheet {
     public static void main(String[] args) {
         //加载文档
         Workbook  wb = new Workbook();
         wb.loadFromFile("ProtectWorksheet.xlsx");
 
         //获取工作表
         Worksheet sheet = wb.getWorksheets().get(0);
 
         //解除密码保护(需输入源文档密码)
         sheet.unprotect("654321");
 
         //保存文档
         wb.saveToFile("UnprotectSheet.xlsx",ExcelVersion.Version2010);
         wb.dispose();
     }
 }

运行程序,生成的文档中,指定工作表将不再受保护。

以上是“Java如何加密/解密Excel”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI