Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

XML Signature

From Wikipedia, the free encyclopedia
XML syntax for digital signatures

XML Signature (also calledXMLDSig,XML-DSig,XML-Sig) defines anXML syntax fordigital signatures and is defined in theW3C recommendationXML Signature Syntax and Processing. Functionally, it has much in common withPKCS #7 but is more extensible and geared towards signing XML documents. It is used by variousWeb technologies such asSOAP,SAML, and others.

XML signatures can be used to sign data–aresource–of anytype, typically XML documents, but anything that is accessible via aURL can be signed. An XML signature used to sign a resource outside its containing XML document is called adetached signature; if it is used to sign some part of its containing document, it is called anenveloped signature;[1] if it contains the signed data within itself it is called anenveloping signature.[2]

Structure

[edit]

An XML Signature consists of aSignature element in thehttp://www.w3.org/2000/09/xmldsig# namespace. The basic structure is as follows:

<Signature><SignedInfo><CanonicalizationMethod/><SignatureMethod/><Reference><Transforms/><DigestMethod/><DigestValue/></Reference><Reference/>etc.</SignedInfo><SignatureValue/><KeyInfo/><Object/></Signature>
  • TheSignedInfo element contains or references the signed data and specifies what algorithms are used.
    • TheSignatureMethod andCanonicalizationMethod elements are used by theSignatureValue element and are included inSignedInfo to protect them from tampering.
    • One or moreReference elements specify the resource being signed by URI reference and any transformations to be applied to the resource prior to signing.
      • Transforms contains the transformations applied to the resource prior to signing. A transformation can be a XPath-expression that selects a defined subset of the document tree.[3]
      • DigestMethod specifies the hash algorithm before applying the hash.
      • DigestValue contains theBase64 encoded result of applying the hash algorithm to the transformed resource(s) defined in theReference element attributes.
  • TheSignatureValue element contains theBase64 encoded signature result - the signature generated with the parameters specified in theSignatureMethod element - of theSignedInfo element after applying the algorithm specified by theCanonicalizationMethod.
  • KeyInfo element optionally allows the signer to provide recipients with the key that validates the signature, usually in the form of one or moreX.509 digital certificates. The relying party must identify the key from context ifKeyInfo is not present.
  • TheObject element (optional) contains the signed data if this is anenveloping signature.

Validation and security considerations

[edit]

When validating an XML Signature, a procedure calledCore Validation is followed.

  1. Reference Validation: EachReference's digest is verified by retrieving the corresponding resource and applying any transforms and then the specified digest method to it. The result is compared to the recordedDigestValue; if they do not match, validation fails.
  2. Signature Validation: TheSignedInfo element is serialized using the canonicalization method specified inCanonicalizationMethod, the key data is retrieved usingKeyInfo or by other means, and the signature is verified using the method specified inSignatureMethod.

This procedure establishes whether the resources were really signed by the alleged party. However, because of the extensibility of the canonicalization and transform methods, the verifying party must also make sure that what was actually signed or digested is really what was present in the original data, in other words, that the algorithms used there can be trusted not to change the meaning of the signed data.

Because the signed document's structure can be tampered with leading to "signature wrapping" attacks, the validation process should also cover XML document structure. Signed element and signature element should be selected using absoluteXPath expression, notgetElementByName methods.[4]

XML canonicalization

[edit]

The creation of XML Signatures is substantially more complex than the creation of an ordinary digital signature because a given XML Document (an "Infoset", in common usage among XML developers) may have more than one legal serialized representation. For example, whitespace inside an XML Element is not syntactically significant, so that<Elem > is syntactically identical to<Elem>.

Since the digital signature ensures data integrity, a single-byte difference would cause the signature to vary. Moreover, if an XML document is transferred from computer to computer, theline terminator may be changed from CR to LF to CR LF, etc. A program that digests and validates an XML document may later render the XML document in a different way, e.g. adding excess space between attribute definitions with an element definition, or using relative (vs. absolute) URLs, or by reordering namespace definitions. Canonical XML is especially important when an XML Signature refers to a remote document, which may be rendered in time-varying ways by an errant remote server.

To avoid these problems and guarantee that logically-identical XML documents give identical digital signatures, an XMLcanonicalization transform (frequently abbreviatedC14n) is employed when signing XML documents (for signing theSignedInfo, a canonicalization is mandatory). These algorithms guarantee that semantically-identical documents produce exactly identical serialized representations.

Another complication arises because of the way that the default canonicalization algorithm handles namespace declarations; frequently a signed XML document needs to be embedded in another document; in this case the original canonicalization algorithm will not yield the same result as if the document is treated alone. For this reason, the so-calledExclusive Canonicalization, which serializesXML namespace declarations independently of the surrounding XML, was created.

Benefits

[edit]

XML Signature is more flexible than other forms of digital signatures such asPretty Good Privacy andCryptographic Message Syntax, because it does not operate onbinary data, but on theXML Infoset, allowing to work on subsets of the data (this is also possible with binary data in non-standard ways, for example encoding blocks of binary data in base64 ASCII), having various ways to bind the signature and signed information, and perform transformations. Another core concept is canonicalization, that is to sign only the "essence", eliminating meaningless differences like whitespace and line endings.

Issues

[edit]

There are criticisms directed at the architecture of XML security in general,[5] and at the suitability of XML canonicalization in particular as a front end to signing and encrypting XML data due to its complexity, inherent processing requirement, and poor performance characteristics.[6][7][8] The argument is that performing XML canonicalization causes excessive latency that is simply too much to overcome for transactional, performance sensitiveSOA applications.

These issues are being addressed in theXML Security Working Group.[9][10]

Without proper policy and implementation[4] the use of XML Dsig in SOAP and WS-Security can lead to vulnerabilities,[11] such as XML signature wrapping.[12]

Applications

[edit]

An example of applications of XML Signatures:

See also

[edit]

References

[edit]
  1. ^"XML Signature Syntax and Processing Version 1.1".
  2. ^"XML Signature Syntax and Processing Version 1.1".
  3. ^XML-Signature XPath Filter 2.0
  4. ^abPawel Krawczyk (2013)."Secure SAML validation to prevent XML signature wrapping attacks". Archived from the original on 2013-12-14. Retrieved2025-01-19.{{cite web}}: CS1 maint: bot: original URL status unknown (link)
  5. ^"Why XML Security is Broken".
  6. ^"Performance of Web Services Security"(PDF). Archived fromthe original(PDF) on 2021-02-24. Retrieved2007-05-21.
  7. ^"Performance Comparison of Security Mechanisms for Grid Services"(PDF). Archived fromthe original(PDF) on 2018-03-28. Retrieved2007-08-12.
  8. ^Zhang, Jimmy (January 9, 2007)."Accelerate WSS applications with VTD-XML".JavaWorld. Retrieved2020-07-24.
  9. ^W3C Workshop on Next Steps for XML Signature and XML Encryption, 2007
  10. ^"XML Security 2.0 Requirements and Design Considerations".
  11. ^"XML Signature Element Wrapping Attacks and Countermeasures"(PDF). IBM Research Division. Archived fromthe original(PDF) on 2016-03-03. Retrieved2023-09-07.
  12. ^Juraj Somorovsky; Andreas Mayer; Jorg Schwenk; Marco Kampmann; Meiko Jensen (2012)."On Breaking SAML: Be Whoever You Want to Be"(PDF).
  13. ^"SBR Assurance". Archived fromthe original on 2023-09-07. Retrieved2023-09-07.

External links

[edit]
Products,
standards
Recommendations
Notes
Working drafts
Guidelines
Initiative
Deprecated
Obsoleted
Groups,
organizations
Elected
Working
Community, business
Closed
Software
Browsers
Conferences
Retrieved from "https://en.wikipedia.org/w/index.php?title=XML_Signature&oldid=1327767048"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2026 Movatter.jp