zoukankan      html  css  js  c++  java
  • Java 添加数字签名到Excel以及检测、删除签名

    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();
        }
    }

    执行程序代码后,生成的结果文档中不再有签名。

    本文完。

    如需转载,务必注明出处!!!

  • 相关阅读:
    Mysql元数据分析
    python编码encode和decode
    自己写的Python数据库连接类和sql语句拼接方法
    【甘道夫】Sqoop1.99.3基础操作--导入Oracle的数据到HDFS
    SVN配置以及自己主动部署到apache虚拟文件夹
    css中使用id和class 的不同
    Android OpenGL ES(七)----理解纹理与纹理过滤
    一键安装 redmine on windows 和发邮件设置
    足球大数据:致足球怀疑论者-The Counter(s)-Reformation反教条改革
    【Android进阶篇】Fragment的两种载入方式
  • 原文地址:https://www.cnblogs.com/Yesi/p/14581516.html
Copyright © 2011-2022 走看看