Incorrect XML Passed to Digest Algorithm when XML Elements Belong to Empty 
Namespace
------------------------------------------------------------------------------------

                 Key: RAMPART-303
                 URL: https://issues.apache.org/jira/browse/RAMPART-303
             Project: Rampart
          Issue Type: Bug
          Components: rampart-core
    Affects Versions: 1.5
         Environment: Windows XP
            Reporter: Niall Tierney
            Assignee: Ruchith Udayanga Fernando


I am using Axis2 1.5.1 and Rampart 1.5 to sign a SOAP request and validate the 
signature on the response, however I am getting a mismatch between the actual 
digest in the XML Signature in the response message and the digest produced by 
Rampart.

To investigate this issue, I implemented a simple Crypto provider that 
implemented the SHA1 digest algorithm.  The provider just writes out the data 
that was sent to it to digest to a file.   It then just calls the default Sun 
implementation to actually compute the digest.  This allowed me to see the XML 
that Rampart was passing to the digest algorithm.

The attached input.xml is the initial signed response document.
When verifying the signature on the response body, rampart produces the 
following output:

> WARNING: Expected Digest: uf7xYFDKnUgQgxBg3SJTSIY/osk= 
> 26-Jul-2010 10:54:56 org.apache.xml.security.signature.Reference verify
> WARNING: Actual Digest: uGqjmTDx7IDyniF7hh5eaQ2ZWjU=

I've taken the message and verified it successfully with a number of XML 
signature implementations, including the Apache one at 
https://svn.apache.org/repos/asf/xml/security/tags/J_1_4_2, which is the 
version that rampart actually uses (i.e. xmlsec-1.4.2.jar ships with Rampart 
1.5).

The attached file correct.dat is the c14n'd form of the body such that 
SHA1(correct.dat) matches the digest in the signature:

> $ openssl sha1 -binary correct.dat | openssl base64
> uf7xYFDKnUgQgxBg3SJTSIY/osk= 

The attached file incorrect.dat is the same reference as passed to the digest 
via rampart:

> $ openssl sha1 -binary incorrect.dat | openssl base64
> uGqjmTDx7IDyniF7hh5eaQ2ZWjU= 

The differences between the two inputs looks as follows:
>
> --- correct.dat 2010-07-26 11:08:54.000000000 +0100
> +++ incorrect.dat       2010-07-26 11:08:54.000000000 +0100
> @@ -1,8 +1,8 @@
> <soap:Body xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/";
>
xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurit
y-utility-1.0.xsd" 
> wsu:Id="Id-0000012a0e1a1572-00000000010a6723-3">
> <GetDirectionsResponse xmlns="http://www.ecubicle.net/webservices/";>
> <GetDirectionsResult>
> - <drivingdirections xmlns="">
> - <route distanceToTravel=" 500 m" finalStep="false" id="0">
> + <drivingdirections>
> + <route>
>                          Head south on Grove St
> </route>
> <totalDistance>739 km</totalDistance>

You can see that rampart has dropped the xmlns="" attribute/namespace 
declaration from the "drivingdirections" element, and also the attributes from 
the route element (indeed, it seems that neither the attribute or namespace 
axes have been entirely eliminated).

Experimentation shows that naiively deleting the default namespace declaration 
(i.e. xmlns="") from the drivingdirections element actually produces a 
signature that rampart can verify, so it is not just systematically eliminating 
theses axes.

This bug seems to resemble Issue 128, but this was logged in December 2007 for 
Rampart 1.3 and is still open.  And since i had a bit more information I 
thought I'd add it in as a new issue.
https://issues.apache.org/jira/browse/RAMPART-128

You can see an example of a Web Service that returns elements in the empty 
namespace (i.e. xmlns="") here:
http://www.ecubicle.net/driving.asmx?wsdl


-- 
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.

Reply via email to