13

私はSpring-WSを初めて使用し、ゆっくりと頭を包み込みます。現在、既存のWSと通信するための単純なクライアントを作成しています。WebServiceTemplateメソッドとmarshalSendAndReceiveメソッドを使用しています。すべてが正常に動作します。

ただし、SOAP障害が発生すると、WSTはSoapFaultClientExceptionをスローします。独自のFaultMessageResolverを作成して、SOAP障害に含まれるものを確認できることに気付きました。ただし、FaultMessageResolverでWebServiceMessageをアンマーシャリングしようとすると、次のエラーメッセージが表示されます。

JAXB unmarshalling exception; nested exception is javax.xml.bind.UnmarshalException: unexpected element (uri:"http://schemas.xmlsoap.org/soap/envelope/", local:"Fault"). Expected elements are ....

明らかに、私のアンマーシャラーは適切に構成されていません。エラーをアンマーシャリングできるようにするには、xjcを使用して自分でJAXB障害モデルを生成する必要がありますか?これがまだ存在していないことに少し驚いています。

私のsoap:fault応答内からカスタムエラー情報を追加するためのより良い方法はありますか?エラーは次のようになり、serviceErrorsアイテムを抽出/アクセスしようとしています。

<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
   <soap:Body>
      <soap:Fault>
         <faultcode>soap:Server</faultcode>
         <faultstring>Blaze Data Error</faultstring>
         <detail>
            <ns14:serviceErrors xmlns="http://www.nb.com/ClientServices/LendingSimulation/CalculateProfitabilityRequest" xmlns:ns13="http://www.nb.com/fw/errorMgmt" xmlns:ns14="http://www.nb.com/ClientServices/LendingSimulation/V1" >
               <ns13:faultstring>ServiceExecutionError</ns13:faultstring>
               <ns13:serviceError>
                  <ns13:errorCode>C10F1013</ns13:errorCode>
                  <ns13:errorType>B</ns13:errorType>
                  <ns13:errorMessage>Unable to retreive additional data</ns13:errorMessage>
                  <ns13:fieldName>Message error received from PHClient :  [An unexpected error code was received : system=PH context=[empty]]</ns13:fieldName>
                  <ns13:systemId>Calculator</ns13:systemId>
                  <ns13:time>2012-06-19 14:45:10.151-0400</ns13:time>
               </ns13:serviceError>
            </ns14:serviceErrors>
         </detail>
      </soap:Fault>
   </soap:Body>
</soap:Envelope>

ありがとう!

エリック

4

2 に答える 2

8

私はを使用してorg.springframework.ws.client.core.WebServiceTemplateいます。Faultアンマーシャリングで同じ問題が発生します。WebServiceTemplateプロパティcheckConnectionForFaultをに設定することで、この問題を解決しましたfalse。したがって、私の場合は、サーバーが障害に対してステータス500を返さなかったことが原因である可能性があります。

次にspring-ws、障害を解析してデフォルトに渡しFaultMessageResolver、定期的SoapFaultClientExceptionにキャッチしました。

しかし、それは私に障害のメッセージしか得られなかったので、カスタムを追加しFaultMessageResolverて同じ行に沿ってメッセージを抽出する必要がありました:

SoapFaultDetail faultDetail = ((SoapMessage) message).getSoapBody().getFault().getFaultDetail();
Iterator<SoapFaultDetailElement> detailEntries = faultDetail.getDetailEntries();
StringBuilder errorMessage = new StringBuilder();

while (detailEntries.hasNext()) {
    SoapFaultDetailElement detailElement = detailEntries.next();
    Node node = ((DOMResult) detailElement.getResult()).getNode();
    CustomServiceFault serviceFault = (CustomServiceFault) marshaller.unmarshal(new DOMSource(node));
    errorMessage.append(serviceFault.getErrorCode() + ": " + serviceFault.getErrorMessage());
}
throw new CustomException(errorMessage.toString());

マーシャラーは、に使用されるものと同じWebserviceTemplateです。

于 2016-09-06T09:13:20.053 に答える
6

<soap:Fault>発生しているエラーに基づいて、ノードから始めてXMLソースのマーシャリングを解除しようとしているようです。Javaコードが表示されない場合、これはおそらくソースをアンマーシャリングしようとしていることを意味します。message.getSoapBody().getFault()

<ns14:serviceErrors>実際には、ノードに到達するためにさらに深く進む必要があります。次のパスでこれに到達できるはずです...多分一度に全部ではないかもしれません:)

message.getSoapBody().getFault().getFaultDetail().getDetailEntries().next()
于 2012-08-03T17:22:06.083 に答える