Неправильная обработка прокси клиента WCF вернула конверт SOAP - PullRequest
1 голос
/ 16 июля 2009

У меня есть веб-сервис PHP в кодировке RPC, который возвращает простой конверт с логическим типом данных. При выполнении трассировки на стороне клиента мыльный конверт выглядит следующим образом перед тем, как перейти в прокси WCF:

<SOAP-ENV:Envelope SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" 
xmlns:ns1="http://sample.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:SOAP-ENC="http://schemas.xmlsoap.org
/soap/encoding/">
  <SOAP-ENV:Body>
    <ns1:ServiceMessageResponse>
       <outgoingVar1>true</outgoingVar1>
    </ns1:ServiceMessageResponse>
  </SOAP-ENV:Body>
</SOAP-ENV:Envelope>

Однако, когда возвращаемое значение выходит на другую сторону прокси, оно изменяется на false. Я пытался добавить xsi: type = "xsd: boolean" в исходящий Var1, но это не помогает. Мыльный конверт - это именно то, чего клиент должен ожидать, но по какой-то причине он не будет правильно его потреблять. Это связано с тем, как настроен веб-сервис PHP, или с прокси WCF? Веб-сервис PHP просто настроен так:

ini_set('soap.wsdl_cache_enabled', '0');
ini_set('soap.wsdl_cache_ttl', '0');
$soapServer = new SoapServer('wsdl/sample.wsdl', array('soap_version' => SOAP_1_1));
$soapServer->addFunction('Service');
$soapServer->handle();

и функция заканчивается простым возвращением true; линия. Здесь ничего сложного. Есть идеи, в чем может быть проблема?

Аннотированный WSDL (удалены тривиальные пространства имен и изменены реальные) выглядит следующим образом:

<wsdl:definitions name="IJLSoapResponse" targetNamespace="http://casey.com"
tns="http://casey.com" xmlns:samp="http://sample.com" ...>
  <wsdl:types>
    <xsd:schema targetNamespace="http://casey.com" ...>
            <xsd:element name="incomingVar1" type="xsd:string" nillable="true"/>
            <xsd:element name="incomingVar2" type="xsd:string" nillable="true"/>
    </xsd:schema>
    <xsd:schema targetNamespace="http://sample.com" ...>
            <xsd:element name="outgoingVar1" type="xsd:boolean" nillable="true"/>
    </xsd:schema>
  </wsdl:types>
  <wsdl:message name="ServiceInput">
    <wsdl:part name="incomingVar1" element="tns:incomingVar1"/>
    <wsdl:part name="incomingVar2" element="tns:incomingVar2"/>
  </wsdl:message>
  <wsdl:message name="ServiceOutput">
    <wsdl:part name="outgoingVar1" element="samp:outgoingVar1"/>
  </wsdl:message>
  <wsdl:portType name="ServicePortType">
    <wsdl:operation name="ServiceMessage" parameterOrder="incomingVar1 incomingVar2">
            <wsdl:input name="ServiceMessageRequest" message="tns:ServiceInput"/>
            <wsdl:output name="ServiceMessageResponse" message="tns:ServiceOutput"/>
    </wsdl:operation>
  </wsdl:portType>
  <wsdl:binding name="ServiceBinding" type="tns:ServicePortType">
    <soap:binding style="rpc" transport="http://schemas.xmlsoap.org/soap/http"/>
    <wsdl:operation name="ServiceMessage">
            <soap:operation soapAction="http://casey.com/soap/Service"/>
            <wsdl:input name="ServiceMessageRequest">
                    <soap:body use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" namespace="http://casey.com"/>
            </wsdl:input>
            <wsdl:output name="ServiceMessageResponse">
                    <soap:body use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" namespace="http://sample.com"/>
            </wsdl:output>
    </wsdl:operation>
  </wsdl:binding>
  <wsdl:service name="ServiceService">
    <wsdl:port name="ServicePort" binding="tns:ServiceBinding">
            <soap:address location="http://casey.com/soap/Service"/>
    </wsdl:port>
  </wsdl:service>
</wsdl:definitions>

Этого должно быть достаточно, чтобы увидеть, как все объявлено ... дайте мне знать, если вам нужно что-то еще разъяснить Спасибо за вашу помощь!

Ответы [ 2 ]

0 голосов
/ 10 сентября 2009

Решение закончилось тем, что имело дело с пространствами имен. Так как они не распространялись правильно, мне нужно было добавить атрибут elementFormDefault = "qualified" в схему. Это заставляет префикс присутствовать в каждом элементе, и это единственный способ, которым я мог бы порадовать .NET. Спасибо за вашу помощь в этом.

0 голосов
/ 16 июля 2009

Можем ли мы увидеть WSDL сервиса? Мне интересно, в каком пространстве имен предполагается использовать outgoingVar1.

Службы, закодированные в RPC, всегда были проблемой из-за неоднозначности того, в каких частях сообщения пространства имен предполагается находиться. Меня не удивит то, что здесь проблема


Следующая привязка работает в soapUI. По крайней мере, он может генерировать фиктивную службу, и ответное сообщение выглядит так, как вы искали (outgoingVar1 в образце пространства имен):

<wsdl:binding name="ServiceBinding" type="tns:ServicePortType">
    <soap:binding style="rpc" transport="http://schemas.xmlsoap.org/soap/http"/>
    <wsdl:operation name="ServiceMessage">
        <soap:operation soapAction="http://casey.com/soap/Service"/>
        <wsdl:input name="ServiceMessageRequest">
            <soap:body parts="incomingVar1 incomingVar2" use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" namespace="http://casey.com"/>
        </wsdl:input>
        <wsdl:output name="ServiceMessageResponse">
            <soap:body parts="outgoingVar1" use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/" namespace="http://sample.com"/>
        </wsdl:output>
    </wsdl:operation>
</wsdl:binding>
...