Java教程

Java 添加、检测和删除Excel数字签名

本文主要是介绍Java 添加、检测和删除Excel数字签名,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

Excel中可添加数字签名以供文档所有者申明文档的所有权或有效性。本篇文章以Java代码示例介绍如何在Excel文档中对数字签名功能进行相关操作,将分别从添加签名到Excel、检测Excel文档是否已签名,以及删除Excel文档等3种需求来展示通过Java代码来实现的方法。

本次代码测试环境

  • Excel版本:2013

  • 编译环境:IntelliJ IDEA2018

  • JDK版本:1.8.0

  • Excel库工具:spire.xls.jar 4.3.4

  • Pfx数字证书(及密码)

方法解释:

Spire.Xls.jar提供了Workbook.addDigitalSignature()方法用于添加数字签名,Workbook.isDigitallySigned()用于检测文档是否签名,以及Workbook.removeAllDigitalSignatures()可删除所有签名。

下面分别以三个代码块来展示如何实现。

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

https://img3.sycdn.imooc.com/61556d6b0001a07013630656.jpg

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

    }
}

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

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

 

—End—


这篇关于Java 添加、检测和删除Excel数字签名的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!