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();
    }
}
复制代码

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

 

本文完。

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

 

posted @   E-iceblue  阅读(528)  评论(0编辑  收藏  举报
编辑推荐:
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 上周热点回顾(2.17-2.23)
· 如何使用 Uni-app 实现视频聊天(源码,支持安卓、iOS)
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
点击右上角即可分享
微信分享提示