XML加密是选择性保护XML特定元素、内容或属性的安全机制,保持其余结构可读;采用标准xenc命名空间封装为合法XML;支持灵活密钥管理并与XML签名协同实现机密性、真实性与完整性。

XML加密是一种专门用于保护XML文档中部分或全部内容的安全机制,它不是加密整个XML文件,而是允许对XML中的特定元素、元素内容或属性进行选择性加密,并保持其余结构可读、可解析。
XML加密支持三种常见加密粒度:
<xenc:EncryptedData>结构id="123"中的"123"),用<xenc:EncryptedKey>等结构替代这种细粒度控制让系统能在不破坏XML语义和处理流程的前提下,只隐藏真正敏感的部分。
加密后的结果仍遵循XML语法,使用W3C定义的http://www.w3.org/2001/04/xmlenc#命名空间。原始数据被替换为标准化的<xenc:EncryptedData>或<xenc:EncryptedKey>元素,包含加密算法标识、密文、IV(初始化向量)、密钥信息(或引用)等。接收方用对应密钥和算法即可原样还原,不影响XPath查询、XSLT转换或SOAP消息路由。
XML加密本身不生成密钥,但规定了如何表达密钥信息:
<xenc:EncryptedKey>(比如用接收方公钥加密会话密钥)KeyInfo引用外部密钥(如证书URI、KeyName、RetrievalMethod)这使得密钥策略能与现有PKI或密钥管理系统集成,避免硬编码密钥或手动协商。
单独加密不能防止篡改。实践中常与XML签名(XML Signature)配合:先签名再加密,或先加密再签名(取决于信任模型)。例如在SOAP消息中,签名保证报文完整性,加密保护机密字段,两者结合实现“机密性+真实性+完整性”三重保障。
基本上就这些。它不复杂但容易忽略细节——比如加密后未更新相关XPath路径,或密钥引用方式与解密端不匹配,都会导致解析失败。
以上就是XML加密(XML Encryption)是什么,它如何保护XML文档中的敏感信息?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号