Я получил следующий wsdl (для ясности вставив только его часть) после того, как он обновил ERP-систему JDEdwards в своей компании.
<message name="createSalesOrder2C">
<part name="createSalesOrder2C" element="tns:createSalesOrder2C"/>
</message>
<message name="createSalesOrder2CResponse">
<part name="createSalesOrder2CResponse" element="tns:createSalesOrder2CResponse"/>
</message>
<message name="BusinessServiceException">
<part name="fault" element="tns:BusinessServiceException"/>
</message>
<portType name="CreateSalesOrderManager">
<operation name="createSalesOrder2C">
<input wsam:Action="http://oracle.e1.bssv.JP5F0013/CreateSalesOrderManager/createSalesOrder2CRequest" message="tns:createSalesOrder2C"/>
<output wsam:Action="http://oracle.e1.bssv.JP5F0013/CreateSalesOrderManager/createSalesOrder2CResponse" message="tns:createSalesOrder2CResponse"/>
<fault message="tns:BusinessServiceException" name="BusinessServiceException" wsam:Action="http://oracle.e1.bssv.JP5F0013/CreateSalesOrderManager/createSalesOrder2C/Fault/BusinessServiceException"/>
</operation>
</portType>
<binding name="CreateSalesOrderManagerPortBinding" type="tns:CreateSalesOrderManager">
<wsp:PolicyReference URI="#bssvpolicy"/>
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/>
<operation name="createSalesOrder2C">
<soap:operation soapAction=""/>
<input>
<soap:body use="literal"/>
</input>
<output>
<soap:body use="literal"/>
</output>
<fault name="BusinessServiceException">
<soap:fault name="BusinessServiceException" use="literal"/>
</fault>
</operation>
</binding>
<service name="CreateSalesOrderManagerService">
<port name="CreateSalesOrderManagerPort" binding="tns:CreateSalesOrderManagerPortBinding">
<soap:address location="https://domain_removed/CreateSalesOrderManager"/>
</port>
</service>
Это часть конечной точки Oracle JDEdwards ERP.
Моя проблема в том, что после обновления определения пропали, и у меня есть только «буквальные» вещи. Перепробовал несколько подходов и закончил:
try{
$soap = new WSSoapClient2($wsdl,[
'cache_wsdl' => WSDL_CACHE_NONE,
'stream_context' => $context,
'trace' => true,
'style' => SOAP_DOCUMENT,
'use' => SOAP_LITERAL,
'location' => 'https://xxx/CreateSalesOrderManager',
]);
$request = array(
'AddressNumber' => 1,
'ShipToNumber' => 1,
'Reference1' => 'ORDER1234',
'RequestedDate' => '2018-03-26T09:00:00',
'Items' => array(
array(
'Quantity' => 5,
'UnitOfMeasure' => 'SZ', // SZ - sztuka - Case Sentitive
'ItemNumber' => '0705',
),
array(
'Quantity' => 14,
'UnitOfMeasure' => 'SZ', // SZ - sztuka - Case Sentitive
'ItemNumber' => '0715',
),
array(
'Quantity' => 17,
'UnitOfMeasure' => 'SZ', // SZ - sztuka - Case Sentitive
'ItemNumber' => '0750',
)
),
);
$response = $soap->createSalesOrder2C($request);
} catch (SoapFault $e){ }
И это дает мне Reqest результат как
<SOAP-ENV:Body>
<ns1:createSalesOrder2C/>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
Понятия не имею, почему он пустой. WSDL, который у меня был в версии до JD Upgrade, имел все определения, и запрос, который я предоставил, создал правильное тело мыла.
После нескольких попыток в свободное время мне удалось решить эту проблему.
JDEdwars был обновлен до другого «стандарта» (WS Standard). и имеет типы, определенные в разных файлах (которые я не заметил)
<types>
<xsd:schema>
<xsd:import
namespace="http://oracle.e1.bssv.JP5F0013/"schemaLocation="https://domain.x/CreateSalesOrderManager?xsd=1"/>
</xsd:schema>
</types>
И проблема была решена путем изменения чувствительности к регистру. Например AddressNumber
стал addressNumber
и это ДЕЛАЕТ дело в этом случае.
Других решений пока нет …