2023-05-03 11:06:20 +02:00
== Why is this an issue?
2022-01-25 10:52:20 +01:00
include::../description.adoc[]
2023-05-03 11:06:20 +02:00
=== Noncompliant code example
2022-01-25 10:52:20 +01:00
2022-02-04 17:28:24 +01:00
[source,java]
2022-01-25 10:52:20 +01:00
----
2022-04-12 21:57:26 +02:00
NodeList signatureElement = doc.getElementsByTagNameNS(XMLSignature.XMLNS, "Signature");
XMLSignatureFactory fac = XMLSignatureFactory.getInstance("DOM");
DOMValidateContext valContext = new DOMValidateContext(new KeyValueKeySelector(), signatureElement.item(0)); // Noncompliant
XMLSignature signature = fac.unmarshalXMLSignature(valContext);
boolean signatureValidity = signature.validate(valContext);
2022-01-25 10:52:20 +01:00
----
2023-05-03 11:06:20 +02:00
=== Compliant solution
2022-04-12 21:57:26 +02:00
In order to benefit from this secure validation mode, set the DOMValidateContext's ``org.jcp.xml.dsig.secureValidation`` property to ``TRUE``.
2022-01-25 10:52:20 +01:00
2022-02-04 17:28:24 +01:00
[source,java]
2022-01-25 10:52:20 +01:00
----
2022-04-12 21:57:26 +02:00
NodeList signatureElement = doc.getElementsByTagNameNS(XMLSignature.XMLNS, "Signature");
XMLSignatureFactory fac = XMLSignatureFactory.getInstance("DOM");
DOMValidateContext valContext = new DOMValidateContext(new KeyValueKeySelector(), signatureElement.item(0));
2022-01-25 10:52:20 +01:00
valContext.setProperty("org.jcp.xml.dsig.secureValidation", Boolean.TRUE);
2022-04-12 21:57:26 +02:00
XMLSignature signature = fac.unmarshalXMLSignature(valContext);
boolean signatureValidity = signature.validate(valContext);
2022-01-25 10:52:20 +01:00
----
2023-05-03 11:06:20 +02:00
== Resources
2022-01-25 10:52:20 +01:00
* https://docs.oracle.com/en/java/javase/14/security/java-xml-digital-signature-api-overview-and-tutorial.html#GUID-DB46A001-6DBD-4571-BDBC-1BBC394BF61E[Oracle Java Documentation] - XML Digital Signature API Overview and Tutorial
* https://owasp.org/www-project-top-ten/2017/A3_2017-Sensitive_Data_Exposure[OWASP Top 10 2017 Category A3] - Sensitive Data Exposure
2022-04-07 08:53:59 -05:00
* https://cwe.mitre.org/data/definitions/347[MITRE, CWE-347] - Improper Verification of Cryptographic Signature
2022-01-25 10:52:20 +01:00
ifdef::env-github,rspecator-view[]
'''
== Implementation Specification
(visible only on this page)
include::../message.adoc[]
'''
2022-01-25 13:38:33 +01:00
== Comments And Links
(visible only on this page)
include::../comments-and-links.adoc[]
2022-01-25 10:52:20 +01:00
endif::env-github,rspecator-view[]