微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

XSLT转换为xmlSignature java?

我有一个 XML文档.我正在使用xmlsignature签署文档的一部分.在找到摘要之前,我想应用XSLT转换.根据我读到的,XSLT将XML文档转换为另一种格式(也可以是XML).现在我很困惑,转换的新文档在哪里可以使用?如果我想显示用户,如何从这个新创建的文档中检索值?
我的XML文档
<r1>
 <user>asd</user>
 <person>ghi</person>
</r1>

转型代码

Transform t=fac.newTransform(Transform.XPATH,new XPathFilterParameterSpec("/r1/user"));

根据xpath转换,每当用户元素的值更改时,xmlsignature不应该被验证.如果person元素的值发生变化,那么Signature应该被验证.但是当我更改person元素的值时,签名不会被验证.为什么?

解决方法

签署文档时使用的xslt变换与计算签名时如何选择源XML中的节点有关.

This question/answerDave涉及使用xpath2签署XML文档的部分.该答案中的link to Sean Mullans’ post表明,xpath2更适合于签署文档的一部分,因为xpath表达式的评估是针对每个节点完成的.

因此,基于sun dsig example,您可以使用以下命令替换参考创建:

List<XPathType> xpaths = new ArrayList<XPathType>();
xpaths.add(new XPathType("//r1/user",XPathType.Filter.INTERSECT));

Reference ref = fac.newReference
  ("",fac.newDigestMethod(DigestMethod.SHA1,null),Collections.singletonList
          (fac.newTransform(Transform.XPATH2,new XPathFilter2ParameterSpec(xpaths))),null,null);

这允许// r1 / user被保护,同时可以修改文档的其余部分.

xpath / xpath2选择的问题是可以为/ some / node /生成一个/是/不/不存在的签名.您是修改测试文档的对象,并确保签名的工作方式符合您的期望.

您可以通过在验证之前生成一个签名然后篡改xml节点来测试测试程序中的文档:

NodeList nlt = doc.getElementsByTagName("user");
nlt.item(0).getFirstChild().setTextContent("Something else");

xpath选择器的一个更可靠的替代方法可能是将您希望签署的xml文档元素的ID放在一起:

<r1>
 <user id="sign1">asd</user>
 <person>ghi</person>
</r1>

然后将此ID作为包络传输的第一个参数中的URI引用:

Reference ref = fac.newReference
  ("#sign1",Collections.singletonList
      (fac.newTransform(Transform.ENVELOPED,(TransformParameterSpec) null)),null);

对于输出,签名操作将向您在内存中加载的DOM添加一个新的Signature元素.您可以通过以下转换来输出输出

TransformerFactory tf = TransformerFactory.newInstance();
Transformer trans = tf.newTransformer();
trans.setoutputProperty(OutputKeys.INDENT,"yes");

trans.transform(new DOMSource(doc),new StreamResult(System.out));

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?