Java 给Excel添加数字签名 Excel VBA使用数字签名

来源:搜狗指南时间:2022-03-15 18:06:02

  Java 给Excel添加数字签名 Excel VBA使用数字签名。Excel中可添加数字签名以供文档所有者申明文档的所有权或有效性。下面介绍如何在Java程序代码中实现给Excel工作簿添加签名。

  工具/材料

  Excel版本:2013

  编译环境:IntelliJ IDEA2018

  JDK版本:1.8.0

  Excel库工具:spire.xls.jar 4.3.4

  数字证书及密码

  操作方法

  01

  在IDEA项目文件夹路径下,存入一个Excel文件,版本为2013版本的xlsx文件;以及已知密码的pfx格式的数字证书。如图:

  02

  在idea项目引入excel库工具spire.xls.jar的包,如图:

  03

  在程序中键入如下代码:

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

  }

  }

  04

  执行程序,生成文档。在结果文档中查看签名添加效果:

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

  }

  }

Java 给Excel添加数字签名 Excel VBA使用数字签名

  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("未签名文档!");

  }

  }

  }

http://img1.sycdn.imooc.com/61556dd60001515e05730190.jpg

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

  }

  }

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

  特别提示

  代码中的路径为IDEA项目文件夹路径,路径也可另外自定义。

文章内容来源于网络,不代表本站立场,若侵犯到您的权益,可联系我们删除。(本站为非盈利性质网站) 联系邮箱:rjfawu@163.com