欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

Java 添加数字签名到excel及检测,删除签名

时间:2021-09-30 08:57:18|栏目:JAVA代码|点击:

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

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

上一篇:在java8中使用流区分质数与非质数详解

栏    目:JAVA代码

下一篇:Java开发常用类库之Hutool详解

本文标题:Java 添加数字签名到excel及检测,删除签名

本文地址:http://www.codeinn.net/misctech/178141.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有