(PHP 5, PHP 7, PHP 8)
SoapClient::__soapCall — Calls a SOAP function
$name
,$args
,$options
= null
,$inputHeaders
= null
,&$outputHeaders
= null
This is a low level API function that is used to make a SOAP call. Usually,
in WSDL mode, SOAP functions can be called as methods of the
SoapClient object. This method is useful in non-WSDL
mode when soapaction
is unknown, uri
differs from the default or when sending and/or receiving SOAP Headers.
On error, a call to a SOAP function can cause PHP to throw exceptions or return a SoapFault object if exceptions are disabled. To check if the function call failed to catch the SoapFault exceptions, check the result with is_soap_fault().
name
The name of the SOAP function to call.
args
An array of the arguments to pass to the function. This can be either an ordered or an associative array. Note that most SOAP servers require parameter names to be provided, in which case this must be an associative array.
options
An associative array of options to pass to the client.
The location
option is the URL of the remote Web service.
The uri
option is the target namespace of the SOAP service.
The soapaction
option is the action to call.
inputHeaders
An array of headers to be sent along with the SOAP request.
outputHeaders
If supplied, this array will be filled with the headers from the SOAP response.
SOAP functions may return one, or multiple values. If only one value is returned
by the SOAP function, the return value of __soapCall
will be
a simple value (e.g. an integer, a string, etc). If multiple values are
returned, __soapCall
will return
an associative array of named output parameters.
On error, if the SoapClient object was constructed with the exceptions
option set to false
, a SoapFault object will be returned.
Example #1 SoapClient::__soapCall() example
<?php
$client = new SoapClient("some.wsdl");
$client->SomeFunction($a, $b, $c);
$client->__soapCall("SomeFunction", array($a, $b, $c));
$client->__soapCall("SomeFunction", array($a, $b, $c), NULL,
new SoapHeader(), $output_headers);
$client = new SoapClient(null, array('location' => "http://localhost/soap.php",
'uri' => "http://test-uri/"));
$client->SomeFunction($a, $b, $c);
$client->__soapCall("SomeFunction", array($a, $b, $c));
$client->__soapCall("SomeFunction", array($a, $b, $c),
array('soapaction' => 'some_action',
'uri' => 'some_uri'));
?>