xml 数字签名 破解

介绍

如您所知,XML在我们的产品或项目开发中起着重要作用,并且从XML文档中我们收集了很多信息,并且我们可以对XML文件执行CRUD操作。 但是,关于如何确保XML文件中可用的数据是真实的以及数据来自受信任的可靠来源,这是一个令人关注的问题。 关于来自XML文件的数据的真实性或独创性,可能存在许多问题。 开发人员通常不考虑数据的真实性而处理XML文档是一种惯例。 但是在某些情况下,您需要解决以上各行提出的所有要点和问题。 让我们考虑一下现实世界的情况,每当我们收到邮局的信件或邮件时,我们如何知道这封信是来自我们的朋友的? 它基于他/她的典型陈述或单词或地址详细信息。 这可能是他/她的角色签名。 有时,我们收到的信件也可能被陌生人添加了另一页所修改。 由于所有这些原因,我们通常会验证朋友的手写签名。 这都是关于普通邮局的信。 电子讯息呢? 我们如何验证电子消息是真实的? 在这种情况下,我们必须采用该技术进行数字签名。 在本文中,我将简要介绍XML数字签名,它对我们的数据完整性起着重要作用。 在本文中,我将向您展示如何将数字签名附加到XML文档,以及如何使用附加的签名验证XML文档。

技术性

在最近几年中,XML Digital Signature获得了强劲的发展,尤其是在金融领域。 在进入XML数字签名之前,让我们考虑一个典型的场景以供我们理解。 考虑一个组织以XML文档的形式将其雇员的所有工资详细信息发送到所得税部门的情况。 现在是一个问题,所得税部门如何验证XML文件? 这意味着IT部门必须验证组织中所有员工的敏感信息。 IT部门必须确保XML文档来自受信任的来源,并且在进入IT部门时尚未对其进行修改。 这意味着文档之间没有进行调整。 首先,我们必须了解数字签名的概念。 数字签名是一种电子签名,用于验证受信任人员发送的文档的真实性。 它还可以确保文档原始内容在传输过程中没有被修改。 数字签名可以与任何消息一起使用,无论它是否经过加密,以便接收者可以确定发送者的身份,并且该消息不会被陌生人更改。 根据Wikipedia的说法,数字签名是一种数学方案,用于证明数字消息或文档的真实性。 有效的数字签名使收件人有理由相信该邮件是由已知的发件人创建的,这样,发件人就无法否认已发送了该邮件(身份验证和不可否认),并且该邮件在传输过程中没有发生更改(完整性)。 数字签名通常用于软件分发,财务交易,以及在其他情况下检测伪造或篡改非常重要的情况。

让我们看一个带有数字签名的完整XML文档。

<?xml version="1.0" encoding="UTF-8" standalone="no"?><SalaryDeposit><Organisation><Name>DDLab Inc</Name><AccountNo>SBC-12345789</AccountNo></Organisation><Employees><Emp><Name>John Abraham</Name><AccountNo>SB-001</AccountNo><Amount>1234</Amount></Emp><Emp><Name>Bipasha Basu</Name><AccountNo>SB-002</AccountNo><Amount>2334</Amount></Emp><Emp><Name>Vidya Balan</Name><AccountNo>SB-003</AccountNo><Amount>3465</Amount></Emp><Emp><Name>Debadatta Mishra</Name><AccountNo>SB-007</AccountNo><Amount>5789</Amount></Emp><Emp><Name>Priti Zinta</Name><AccountNo>SB-009</AccountNo><Amount>1234</Amount></Emp></Employees><Signature xmlns="http://www.w3.org/2000/09/xmldsig#"><SignedInfo><CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/><SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/><Reference URI=""><Transforms><Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/></Transforms><DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><DigestValue>bHS+6uf8KbJV4AGzoHNHLfnXvKM=</DigestValue></Reference></SignedInfo><SignatureValue>
aUEMrCT5dzeOfSNaznzoT0If8WZ8KQcMNXDqtoeseonVk3NqOk9ctcxrf3QVX3wP6810DDRPdI6le8ccG64Ge0HjkO+aYC5+c2L/qKBzwtSbl/olJEuFU2DVxBQO+K29TTUJfxpVzC9Zf2pvT+1NRj0f2/ofHujYZ01D6+YqI8c=</SignatureValue><KeyInfo><KeyValue><RSAKeyValue><Modulus>
jfAd5uV38L36+lDZJrqfH9oLN86VJezXYfAeU+lrFoHlKAXVJLAi9hKvBHQRer4tPfdez6iSBKsl6IHkPnVRAKt0xU99uxi5QpymsWAX3qnBqHlw9Z70PwyZ+Xysfw4Q2tK2HtSgUOhMuaUcIf9sbHvfgbvcRPgxDZZqfIzDmDU=</Modulus><Exponent>AQAB</Exponent></RSAKeyValue></KeyValue></KeyInfo></Signature>
</SalaryDeposit>

上面的XML文件是经过数字签名的文件,可以在任何时间进行验证。 上面的XML文件包含有关员工姓名,帐号和薪水金额的信息。 但是实际的数字签名附加在标签<Signature> </ Signature>中。 <Signature>中的信息提供了文档的真实性。 由于可以看到数据,因此可以自由更改数据,但是在签名验证过程中它将失败。

基本上,存在三种类型的XML签名。

  • 信封签名
  • 信封签名
  • 分离的签名

信封签名

在这种情况下,签名是经过签名的XML对象的子级。 这意味着<Signature>是邮件XML文档中的子XML标记。 以下是信封数字签名的结构。

<RootElement>
<Signature>
……………………
</Signature>
</ RootElement>

在本文中,我将向您介绍如何创建封装的XML数字签名。

信封签名

在这种情况下,XML文档仍保留在Signature对象中。 这意味着<Signature>标记将成为已签名XML文档的根元素。 以下是信封数字签名的概述。

<Signature >
< MyXMLDocument >
…
</ MyXMLDocument >
</Signature>

分离签名

在这种情况下,数字签名是独立生成的,并且不是XML文档的一部分。 这意味着您将有两个XML文件,一个是要签名的XML文件,另一个是XML签名。 让我们看一下XML文档的骨架结构。

<Signature>
…………..
</Signature>

现在让我们在下面看到典型的XML数字签名的骨架结构。

<Signature xmlns="">
<SignedInfo>
<CanonicalizationMethod
Algorithm="" />
<SignatureMethod Algorithm="" />
<Reference URI="">
<Transforms>
<Transform Algorithm="" />
</Transforms>
<DigestMethod Algorithm="" />
<DigestValue></DigestValue>
</Reference>
</SignedInfo>
<SignatureValue></SignatureValue>
<KeyInfo>
<KeyValue>
<RSAKeyValue>
<Modulus></Modulus>
<Exponent></Exponent>
</RSAKeyValue>
</KeyValue>
</KeyInfo>
</Signature>

XML标记<Signature>基本上包含3个子标记。 它可以被视为

<Signature>
<SignedInfo></SignedInfo>
<SignatureValue></SignatureValue>
<KeyInfo></KeyInfo>
</Signature>

这里的<Signature>是XML数字签名概念的根元素,并且是W3C所必须遵循的协议。 <SignedInfo>元素是您签名的信息。 <SignatureValue>包含带有Base64编码内容的实际签名,最后<KeyInfo>表示公共密钥。 再次让我们看一下<SignedInfo>标签。 <SignedInfo>的结构如下。

<SignedInfo>
<CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
<SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
<Reference URI="">
<Transforms>
<Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
</Transforms>
<DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
<DigestValue>bHS+6uf8KbJV4AGzoHNHLfnXvKM=</DigestValue>
</Reference>
</SignedInfo>

在java中创建XML数字签名时,SignedInfo对象用于在数字签名的Signature标签内创建一个元素。 这也是W3C建议的XML数字签名协议的一部分。

现在让我们看一下下面的XML标签<KeyInfo>结构。

<KeyInfo>
<KeyValue>
<RSAKeyValue>
<Modulus></Modulus>
<Exponent></Exponent>
</RSAKeyValue>
</KeyValue>
</KeyInfo>

<KeyInfo>标记包含数学计算的信息,基本上它包含公钥的模数和指数。

为了创建XML数字签名,请遵循以下步骤。

  1. 生成一对称为私钥和公钥的密钥。
  2. 获取原始XML文档。
  3. 通过Java API使用私钥和公钥对原始XML文档签名,然后生成另一个具有XML数字签名的文档。

让我们看一下用于生成XML数字签名的简短Java代码段。

public void generateXMLDigitalSignature(String originalXmlFilePath,
String destnSignedXmlFilePath, String privateKeyFilePath, String publicKeyFilePath) {
//Get the XML Document object
Document doc = getXmlDocument(originalXmlFilePath);
//Create XML Signature Factory
XMLSignatureFactory xmlSigFactory = XMLSignatureFactory.getInstance("DOM");
PrivateKey privateKey = new KryptoUtil().getStoredPrivateKey(privateKeyFilePath);
DOMSignContext domSignCtx = new DOMSignContext(privateKey, doc.getDocumentElement());
Reference ref = null;
SignedInfo signedInfo = null;
try {
ref = xmlSigFactory.newReference("", xmlSigFactory.newDigestMethod(DigestMethod.SHA1, null),
Collections.singletonList(xmlSigFactory.newTransform(Transform.ENVELOPED,
(TransformParameterSpec) null)), null, null);
signedInfo = xmlSigFactory.newSignedInfo(
xmlSigFactory.newCanonicalizationMethod(CanonicalizationMethod.INCLUSIVE,
(C14NMethodParameterSpec) null),
xmlSigFactory.newSignatureMethod(SignatureMethod.RSA_SHA1, null),
Collections.singletonList(ref));
} catch (NoSuchAlgorithmException ex) {
ex.printStackTrace();
} catch (InvalidAlgorithmParameterException ex) {
ex.printStackTrace();
}
//Pass the Public Key File Path
KeyInfo keyInfo = getKeyInfo(xmlSigFactory, publicKeyFilePath);
//Create a new XML Signature
XMLSignature xmlSignature = xmlSigFactory.newXMLSignature(signedInfo, keyInfo);
try {
//Sign the document
xmlSignature.sign(domSignCtx);
} catch (MarshalException ex) {
ex.printStackTrace();
} catch (XMLSignatureException ex) {
ex.printStackTrace();
}
//Store the digitally signed document inta a location
storeSignedDoc(doc, destnSignedXmlFilePath);
}

XML签名验证

XML数字签名验证涉及以下操作。

  • 验证数字签名

    • 计算<SignedInfo>元素的摘要

为了验证签名的XML文档,请按照下列步骤操作。

  1. 获取签名的XML文档和公共密钥。
  2. 验证<SignedInfo>元素的数字签名
  3. 计算<SignedInfo>元素的摘要并比较这些值。

让我们看一下XML数字签名验证的简短Java代码段。

public static boolean isXmlDigitalSignatureValid(String signedXmlFilePath,
String pubicKeyFilePath) throws Exception {
boolean validFlag = false;
Document doc = getXmlDocument(signedXmlFilePath);
NodeList nl = doc.getElementsByTagNameNS(XMLSignature.XMLNS, "Signature");
if (nl.getLength() == 0) {
throw new Exception("No XML Digital Signature Found, document is discarded");
}
PublicKey publicKey = new KryptoUtil().getStoredPublicKey(pubicKeyFilePath);
DOMValidateContext valContext = new DOMValidateContext(publicKey, nl.item(0));
XMLSignatureFactory fac = XMLSignatureFactory.getInstance("DOM");
XMLSignature signature = fac.unmarshalXMLSignature(valContext);
validFlag = signature.validate(valContext);
return validFlag;
}

因此,从上面的代码中可以明显看出,可以使用<SignatureMethod>元素中指定的摘要算法重新计算<SignedInfo>元素的摘要值,并使用公钥来验证XML签名,以验证该值<SignatureValue>元素的“摘要”对于<SignedInfo>元素的摘要值是正确的。 在<SignedInfo>元素内重新计算引用的摘要,并将它们与每个<Reference>元素的相应<DigestValue>元素中包含的摘要值进行比较。 仍然让我们熟悉一些负责XML数字签名的java组件。

XMLSignatureFactory

它是一个工厂对象,用于使用“ DOM”机制类型为XML文档生成数字签名。 以下列方式创建对象。

XMLSignatureFactory factory = XMLSignatureFactory.getInstance("DOM");

DOMSignContext

DOMSignContext对象用于形成DOM树,在创建数字签名时将在其中附加XML数字签名。 该对象接受私钥和XML文档的根元素。

参考

引用对象用于在XML数字签名的主要Signature标签的SignedInfo元素内作为元素创建。 该对象创建一个标签,作为W3C XML签名语法和处理规则的一部分。 参考元素的基本结构如下。

<Reference URI="">
<Transforms>
<Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
</Transforms>
<DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
<DigestValue>bHS+6uf8KbJV4AGzoHNHLfnXvKM=</DigestValue>
</Reference>

SignedInfo

类似地,SignedInfo对象用于在数字签名的Signature标签内创建一个元素。 这也是W3C建议的XML数字签名协议的一部分。

基本结构如下。

<SignedInfo>
<CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
<SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
<Reference URI="">
<Transforms>
<Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
</Transforms>
<DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
<DigestValue>bHS+6uf8KbJV4AGzoHNHLfnXvKM=</DigestValue>
</Reference>
</SignedInfo>

XML签名

最后,创建XMLSignature对象以形成签名标签,该签名标签用作附加到XML文档的信封。 按照W3C准则,这是XML数字签名的根元素。

完整的结构如下。

<Signature xmlns="http://www.w3.org/2000/09/xmldsig#">
<SignedInfo>
<CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
<SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
<Reference URI="">
<Transforms>
<Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/>
</Transforms>
<DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
<DigestValue>bHS+6uf8KbJV4AGzoHNHLfnXvKM=</DigestValue>
</Reference>
</SignedInfo>
<SignatureValue>aUEMrCT5dzeOfSNaznzoT0If8WZ8KQcMNXDqtoeseonVk3NqOk9ctcxrf3QVX3wP6810DDRPdI6l
e8ccG64Ge0HjkO+aYC5+c2L/qKBzwtSbl/olJEuFU2DVxBQO+K29TTUJfxpVzC9Zf2pvT+1NRj0f
2/ofHujYZ01D6+YqI8c=</SignatureValue>
<KeyInfo>
<KeyValue>
<RSAKeyValue>
<Modulus>jfAd5uV38L36+lDZJrqfH9oLN86VJezXYfAeU+lrFoHlKAXVJLAi9hKvBHQRer4tPfdez6iSBKsl
6IHkPnVRAKt0xU99uxi5QpymsWAX3qnBqHlw9Z70PwyZ+Xysfw4Q2tK2HtSgUOhMuaUcIf9sbHvf
gbvcRPgxDZZqfIzDmDU=</Modulus>
<Exponent>AQAB</Exponent>
</RSAKeyValue>
</KeyValue>
</KeyInfo>
</Signature>

要完全理解,请从此站点下载完整的Netbeans项目,其中包含完整的源代码。

组态

您可以从该站点下载Java中XML数字签名的完整项目,也可以从下面的保管箱链接下载。

  • https://www.dropbox.com/s/0k1iukhy0in6n8h/xmldigitalsignature1.zip

您可以在您喜欢的Java IDE中配置该项目,然后运行测试源文件夹中提供的独立程序。 该项目已经包含私钥和公钥。 如果要生成,请运行Java类“ TestGenerateKeys”以生成一对密钥。 您还可以提供自己的XMl文件的路径,以查看XML数字签名是如何生成的。

结论

希望您喜欢我关于Java中的XML数字签名的文章。 创建XML数字签名的方法也很多,我仅提供了使用Java API生成封装的数字XML签名的方法。 下载完整的项目并查看源代码,以了解概念及其用法。 为了更清楚起见,我在资源和参考部分中提供了一些基本链接。 如有任何问题和错误,请随时通过debadatta.mishra@gmail.com与我联系。

资源与参考

  • http://en.wikipedia.org/wiki/XML_Signature
  • http://msdn.microsoft.com/en-us/library/ms996502.aspx
  • http://www.xml.com/pub/a/2001/08/08/xmldsig.html

翻译自: https://www.javacodegeeks.com/2013/10/xml-security-with-digital-signature-in-java.html

xml 数字签名 破解

xml 数字签名 破解_JAVA中带有数字签名的XML安全性相关推荐

  1. JAVA中带有数字签名的XML安全性

    介绍 如您所知,XML在我们的产品或项目开发中起着重要作用,并且从XML文档中我们收集了很多信息,而且我们可以对XML文件执行CRUD操作. 但是,关于如何确保XML文件中可用的数据是真实的以及数据来 ...

  2. java读取xml路径问题_java 中读取xml 和绝对路径

    一.得到绝对路径 本人用到的不多,就列举常用的. 以上2种可读取固定配置文件可用得到绝对路径 1.System.getProperty("user.dir"); 这个东西局限性十分 ...

  3. java xml格式验证_Java中对XML文件的校验

    Java中使用dtd校验xml文件: 1.定义一个校验类CheckXML类: import org.w3c.dom.Document; import org.xml.sax.EntityResolve ...

  4. java 时间戳验证_Java中带有时间戳的数字签名

    我在使用受信任的时间戳与Bouncy Castle创建有效的CMS签名时遇到问题.签名创建工作良好(我想将签名包括到PDF文件中),签名有效.但是,当我在签名的未签名属性表中添加可信时间戳后,签名仍然 ...

  5. java xml 实体类_java中的xml与实体类之间的映射

    实体类: package xml; import javax.xml.bind.annotation.XmlRootElement; @XmlRootElement public class User ...

  6. netsuite 数据集成_Java中带有NetSuite数据实体的对象关系映射(ORM)

    netsuite 数据集成 对象关系映射(ORM)技术使使用关系数据源更加容易,并且可以将逻辑业务模型与物理存储模型联系在一起. 遵循本教程,将NetSuite数据的连接集成到基于Java的ORM框架 ...

  7. jwebsocket传图片_Java中带有JWebSocket的WebServerSocket

    jwebsocket传图片 首先,转到http://jwebsocket.org/下载2个软件包Server and Client. 如果要查看源代码,请下载源代码包. 服务器 解压缩服务器程序包. ...

  8. java expression 强制出现_Java中带有强制括号对的单行循环

    for 定义如下. BasicForStatement: for ( ForInitopt ; Expressionopt ; ForUpdateopt ) Statement ForStatemen ...

  9. java url json字符串_JAVA中带有JSON字符串的HTTP POST请求

    我必须使用已经生成的JSON字符串发出http Post请求.我尝试了两种不同的方法: 1.HttpURLConnection 2.HttpClient 但是我从两个人那里得到了相同的"不需 ...

最新文章

  1. c++中ifstream一次读取整个文件
  2. 什么是pdh光端机?pdh光端机产品优点介绍!
  3. consul作为服务注册中心
  4. 学术会议 | 中国杭州举办——第21届国际语义网大会​ISWC2022 Call for Papers
  5. ZeroMQ全面介绍
  6. 针对SQL INJECTION的SQL SERVER安全设置初级篇
  7. Element中 el-tag 点击事件 el-tag添加@click事件无效
  8. 计算机和口腔医学都不错的学校,人民日报推荐“各省”好大学,并非只有985/211,普本也有好大学...
  9. 一个小小的抽奖活动测试脚本(python2.7)
  10. Ubuntu的多文件编译以及c语言的数组、函数
  11. Volley,Okhttp,Retrofit源码研究心得大总结
  12. Centos 安装Java JDK8
  13. 【干货】移动APP测试用例设计实践经验分享
  14. 利用 bat 脚本强制杀死 Windows 进程
  15. 论文写作---matlab符号运算之求解方程组
  16. 如何解决'chromedriver' executable needs to be in PATH.的问题
  17. 推特员工大规模辞职,马斯克被“问候”;腾讯10多万员工平均月薪超8万;雪欲“白嫖”网易百万玩家数据...
  18. 嵌入式Linux开发环境搭建-4-嵌入式编程基础知识
  19. 数据结构与算法(C语言版)---魔王语言
  20. 水果酒技术-山楂酒怎么做,山楂酒有几种制作方法

热门文章

  1. 深入理解Java ClassLoader及在 JavaAgent 中的应用
  2. 正则表达式真的很骚,可惜你不会写
  3. java Date获取 年月日时分秒
  4. 加油四班!加油佟穆!我们的征途是星辰大海!!!
  5. javaWeb服务详解(含源代码,测试通过,注释) ——applicationContext.xml
  6. 断言、触发器、存储过程
  7. 表单中去掉重置和提交按钮和搜索框
  8. php中对象的遍历输出,PHP中的对象遍历技巧
  9. (转)Elasticsearch 聚合查询、桶聚合、管道聚合及复合查询
  10. java分布式对象——远程方法中的参数和返回值+远程对象激活