使用XSLT转换时,XML数字签名验证失败

时间:2017-08-09 09:51:44

标签: java xml validation xslt digital-signature

我正在尝试验证包含XSLT转换的XML文件的数字签名。但是,当我验证此消息时,我收到以下错误:

  

javax.xml.crypto.MarshalException:   java.security.InvalidAlgorithmParameterException:XSLT转换   不支持指定的参数元素:xsl:transform

该文件的签名包含如下所示的转换:

<xsl:transform xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    version="1.0">
    <xsl:output encoding="UTF-8" indent="no" method="xml"
        omit-xml-declaration="yes" standalone="yes" version="1.0" />
    <xsl:template match="@*|*">
        <xsl:copy>
            <xsl:apply-templates select="@*|*" />
            <xsl:apply-templates select="text()" />
        </xsl:copy>
    </xsl:template>
    <xsl:template match="text()">
        <xsl:choose>
            <xsl:when test="../@codering = 'base64'">
                <xsl:value-of select="translate(normalize-space(.), ' ', '')" />
            </xsl:when>
            <xsl:otherwise>
                <xsl:value-of select="normalize-space(.)" />
            </xsl:otherwise>
        </xsl:choose>
    </xsl:template>
</xsl:transform>

用于验证xml文件的代码如下所示:

DocumentBuilderFactory documentBuilderFactory = documentBuilderFactory.newInstance();
documentBuilderFactory.setNamespaceAware(true);
Document xmlDocument = documentBuilderFactory.newDocumentBuilder().parse(new ByteArrayInputStream(document.getBytes()));
NodeList nodeList = xmlDocument.getElementsByTagNameNS(XMLSignature.XMLNS, "Signature");
DOMValidateContext domValidateContext = new DOMValidateContext(new RsaSha256KeySelector(), nodeList.item(0));
XMLSignatureFactory xmlSignatureFactory = XMLSignatureFactory.getInstance("DOM");
XMLSignature signature = xmlSignatureFactory.unmarshalXMLSignature(domValidateContext);
signatureIsValid = signature.validate(domValidateContext);

任何人都知道我在这里做错了什么?

由于

1 个答案:

答案 0 :(得分:0)

找到解决问题的方法。显然,java XSLT转换仅支持xsl:stylesheet而不支持xsl:transform。 Althou W3C XSLT规范将其定义为同义词。