温馨提示×

温馨提示×

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

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

Java如何加密/解密Excel

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

小编给大家分享一下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