XMLSec: Что не так с подписью? (Ссылка на URI не имеет XMLSignatureInput)

Я использую apache-santuario 1.4.4 для создания этого подписанного сообщения:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:SOAP-SEC="http://schemas.xmlsoap.org/soap/security/2000-12">
  <soapenv:Header>
    <ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#">
      <ds:SignedInfo>
        <ds:CanonicalizationMethod Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
        <ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/>
        <ds:Reference URI="#DS-OM">
          <ds:Transforms>
            <ds:Transform Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
          </ds:Transforms>
          <ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
          <ds:DigestValue>8nZkH.....99alYEU4=</ds:DigestValue>
        </ds:Reference>
      </ds:SignedInfo>
      <ds:SignatureValue>
        XSwt/8HzsnWewj.....8dHwY+FVCkhlg==
      </ds:SignatureValue>
      <ds:KeyInfo>
        <ds:X509Data>
          <ds:X509Certificate>
            MIID4TCCAsmgAwIB....WQuq/eiErGfyU9ZNmKFpA==
          </ds:X509Certificate>
        </ds:X509Data>
        <ds:KeyValue>
          <ds:RSAKeyValue>
            <ds:Modulus>
              zSmjLBHhvxfE03pEUaq8x.....D4b63mMF8p+3XAYmgw==
            </ds:Modulus>
            <ds:Exponent>AQBA</ds:Exponent>
          </ds:RSAKeyValue>
        </ds:KeyValue>
      </ds:KeyInfo>
    </ds:Signature>
  </soapenv:Header>
  <soapenv:Body SOAP-SEC:Id="DS-OM">
    <ns1:Servic xmlns:ns1="http://www.foo.es/Schemas">
      ...
    </ns1:Servic>
  </soapenv:Body>
</soapenv:Envelope>

Когда я отправляю его в службу, с которой я работаю, она отвечает так:

<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <soapenv:Body>
    <soapenv:Fault>
      <faultcode xmlns:ns1="http://www.foo.com/Schemas">ns1:DigitalSignatureError</faultcode>
      <faultstring>The Reference for URI #DS-OM has no XMLSignatureInput</faultstring>
      <detail>
         <string/>
      </detail>
    </soapenv:Fault>
  </soapenv:Body>
</soapenv:Envelope>

Я много гуглил, но почти ничего не нашел об этой ошибке. Ссылка объявлена ​​плохой? что может быть не так? Любая идея будет оценена.

Заранее спасибо.


person mdiez    schedule 23.02.2011    source источник


Ответы (1)


"DS-OM" определяется как "SOAP-SEC:Id" - я думаю, что именно это вызывает здесь проблему, возможно, SOAP-SEC:Id не является правильным xml:id или неправильно распознается как один . Что вы можете сделать, чтобы обойти это, так это объявить свой Reference, используя вместо этого преобразование XPath:

<ds:Reference URI="">
      <ds:Transforms>
        <ds:Transform Algorithm="http://www.w3.org/TR/1999/REC-xpath-19991116">
           <ds:XPath xmlns:soapenv="&soapenv;" xmlns:SOAP-SEC="&SOAP-SEC;">
             //soapenv:Envelope[@SOAP-SEC:Id='DS-OM']
           <ds:XPath>
        <ds:Transform Algorithm="http://www.w3.org/TR/2001/REC-xml-c14n-20010315"/>
      </ds:Transforms>
      ....
</ds:Reference>
person emboss    schedule 29.08.2011