我试图使用命名空间来处理根元素,并提供对库xml密码的引用。
我没有给出正确的路径,请告知。目的是对文档进行签名,以便在标记<samlp:Response之后插入签名。
<samlp:Response xmlns:samlp="urn:oasis:names:tc:SAML:2.0:protocol" ID="efedb3b0-909f-4b39-b8c0-57427ee8dc83" Version="2.0" IssueInstant="2019-11-08T15:34:51.272Z">
<saml:Issuer xmlns:saml="urn:oasis:names:tc:SAML:2.0:assertion">http://www.example.com</saml:Issuer>
</samlp:Response>nodeJS代码
var SignedXml = require('xml-crypto').SignedXml, fs = require('fs');
var sig = new SignedXml();
sig.addReference("//*[local-name(.)='samlp:Response']");
sig.signingKey = fs.readFileSync(__dirname + "/client.pem");
sig.computeSignature(xml);
fs.writeFileSync(__dirname + "/signed.xml", sig.getSignedXml());尝试
sig.addReference("//samlp:Response");错误:无法解析QName采样
发布于 2019-11-08 16:28:16
如果希望击败/绕过命名空间,则更改
sig.addReference("//*[local-name(.)='samlp:Response']");至
sig.addReference("//*[local-name()='Response']");因为命名空间前缀samlp不是本地名称Response的一部分。
有关XPath中名称空间的全面答案,请参见XPath如何处理XML名称空间?
https://stackoverflow.com/questions/58770257
复制相似问题