Java 添加数字签名到Excel以及检测、删除签名
程序猿小军 · 554浏览 · 发布于2021-03-26
Excel中可添加数字签名以供文档所有者申明文档的所有权或有效性。文本以Java代码示例介绍如何在Excel文档中对数字签名功能进行相关操作,包括如何添加签名到Excel、检测Excel文档是否已签名,以及如何删除Excel文档中的签名。
本次代码测试环境
Excel版本:2013
编译环境:IntelliJ IDEA2018
JDK版本:1.8.0
Excel库工具:spire.xls.jar 4.3.4
Pfx数字证书(及密码)
下面分别以三个代码块来展示如何实现。
1. 添加签名
import com.spire.xls.*; import com.spire.xls.digital.CertificateAndPrivateKey; import java.util.Date; public class AddSignature { public static void main(String[] args) throws Exception { //加载Excel工作簿 Workbook wb = new Workbook(); wb.loadFromFile("test.xlsx"); //添加数字签名 wb.addDigitalSignature(new CertificateAndPrivateKey("cer.pfx","123654yes!"), "The Author is Mia",new Date()); //保存文档 wb.saveToFile("AddSignature.xlsx",ExcelVersion.Version2013); wb.dispose(); } }
签名添加结果:
2.检测是否签名
import com.spire.xls.*; public class DetectSignature { public static void main(String[] args) { //加载Excel工作簿 Workbook wb = new Workbook(); wb.loadFromFile("AddSignature.xlsx"); //判断文档是否签名 boolean signature = wb.isDigitallySigned(); if(signature==true) { System.out.println("文档已签名!"); } else { System.out.println("未签名文档!"); } } }
检测结果:
3.删除签名
import com.spire.xls.*; public class RemoveSignature { public static void main(String[] args) { //加载Excel工作簿 Workbook wb = new Workbook(); wb.loadFromFile("AddSignature.xlsx"); //删除签名 wb.removeAllDigitalSignatures(); //保存文档 wb.saveToFile("RemoveSignature.xlsx",ExcelVersion.Version2013); wb.dispose(); } }
执行程序代码后,生成的结果文档中不再有签名。
相关推荐
PHP实现部分字符隐藏
沙雕mars · 1324浏览 · 2019-04-28 09:47:56
Java中ArrayList和LinkedList区别
kenrry1992 · 907浏览 · 2019-05-08 21:14:54
5月语言排行榜:R 跌出前二十,Python 紧咬 C++
manongba · 686浏览 · 2019-05-09 17:27:24
Tomcat 下载及安装配置
manongba · 967浏览 · 2019-05-13 21:03:56
什么是SpringBoot
iamitnan · 1086浏览 · 2019-05-14 22:20:36
分类专栏
最新发布
最热排行
0评论