通八洲科技

XML签名(XML Signature)是什么 数字签名实现方法

日期:2025-12-30 00:00 / 作者:畫卷琴夢
XML签名是W3C标准的数字签名机制,可精确签名XML文档某一部分或外部资源;核心结构含SignedInfo、SignatureValue、KeyInfo(可选)和Object(可选);分为包络式、分离式和包络内式三类;实现需密钥对、Reference构造、XML规范化(C14N)及签名验证四步闭环。

XML签名(XML Signature,也称XML-DSig)是一种由W3C标准化的数字签名机制,专为XML数据设计,用于保障消息来源可信、内容未被篡改。它不是简单地把XML当二进制文件哈希签名,而是能精确签名XML文档的**某一部分**(如某个元素、属性或子树),甚至可签名外部资源(如图片、JSON、HTML等可通过URI访问的数据)。

XML签名的核心结构

一个XML签名以元素为核心,通常嵌入在XML文档中或独立存在。其关键组成部分包括:

三种常见签名形式

根据签名与被签名数据的位置关系,XML签名分为三类:

数字签名实现的关键步骤

实际编程中(如.NET或Java),签名流程本质是四步闭环:

为什么不能跳过规范化?

XML允许等价但字节不同的表达方式,比如属性顺序、命名空间前缀、空白符位置等。例如:



二者语义完全相同,但原始字符串哈希值不同。C14N算法将它们转为唯一标准序列,确保签名与验证端“看到同一份字节流”。漏掉这步,签名必然失败。