0

0

如何用Java给XML文档添加数字签名 XMLSignature API

幻夢星雲

幻夢星雲

发布时间:2025-12-21 08:40:03

|

455人浏览过

|

来源于php中文网

原创

Java中使用XMLSignature API为XML文档添加数字签名需严格遵循W3C规范,核心步骤包括:准备PKCS#12密钥对、构造SignedInfo指定SHA-256/RSA-SHA256等算法、设置Exclusive规范化、插入ds:Signature节点并签名,最后用DOMValidateContext验证。

如何用java给xml文档添加数字签名 xmlsignature api

Java中使用XMLSignature API为XML文档添加数字签名,核心是通过javax.xml.crypto.dsig包中的类构建签名对象、选择签名算法、引用待签名数据,并用私钥完成签名。整个过程需严格遵循W3C XML Signature规范(如http://www.w3.org/2000/09/xmldsig#),否则生成的签名可能无法被其他系统(如SAML服务、WS-Security网关)正确验证。

准备密钥对和证书

签名前必须有有效的密钥对。推荐使用PKCS#12格式的密钥库(.p12或.pfx),它同时包含私钥和对应证书链:

  • 可用keytool -genkeypair生成,或用OpenSSL导出已有密钥
  • 加载时用KeyStore读取,通过别名获取PrivateKeyX509Certificate
  • 务必确保私钥不暴露、证书未过期、且公钥能被验签方信任(例如已导入对方信任库)

构造SignedInfo并指定签名算法

SignedInfo是签名的核心元数据,定义了摘要算法、签名算法和引用规则:

  • 常用摘要算法:SHA-256(对应URI http://www.w3.org/2001/04/xmlenc#sha256
  • 常用签名算法:RSA-SHA256(URI http://www.w3.org/2001/04/xmldsig-more#rsa-sha256)或ECDSA-SHA256
  • 每个Reference需设置Transforms(如CanonicalizationMethod.EXCLUSIVE)以保证规范化一致,避免因空白、命名空间前缀差异导致验签失败

绑定签名到XML文档并生成Signature元素

签名不是覆盖原文,而是在XML中插入<Signature>节点(通常放在<ds:Signature>命名空间下):

Glimmer Ai
Glimmer Ai

基于GPT-3和DALL·E2的PPT制作工具

下载

立即学习Java免费学习笔记(深入)”;

  • DOMSignContextXMLSignature对象绑定到目标Document的某个位置(例如根元素末尾或特定父节点)
  • 调用sign()触发计算:对每个ReferenceURI定位内容 → 规范化 → 摘要 → 签名运算
  • 生成的<SignatureValue>是Base64编码的原始签名字节<X509Data>可嵌入证书用于验签方提取公钥

验证签名是否有效(调试必备)

签名后立即用XMLSignatureFactory.newXMLSignature()配合DOMValidateContext验证,可快速发现常见问题

  • URI引用路径错误(如#id但目标元素无Id属性或未声明xml:id
  • 规范化方式不匹配(签名用Exclusive,验签时误用Inclusive)
  • 证书链不可信或时间不在有效期
  • 注意:验证时需提供公钥或让KeySelector<X509Data>自动提取证书

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1948

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2119

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1168

2024.11.28

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

497

2023.08.14

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

495

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

450

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

3566

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2911

2024.08.16

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号