如何捕获传出的soapclient请求?

时间:2011-11-10 21:45:14

标签: php soap-client

我尝试了几个可能的解决方案(例如使用ob_),但我没有运气。

我希望能够显示以筛选传出请求以进行调试。

1 个答案:

答案 0 :(得分:2)

我通过扩展SoapClient和重写方法(例如_soapcall() _doRequest()来调试SoapClient。在我的项目中,我有一个将XML /争论写入文件的记录器。

我的示例包括 _ soapCall() _doRequest() 。我在两种方法中打印出不同的东西。可能适合您的调试需求。我喜欢从__soapCall()读取$ args输出,并喜欢将XML复制到SoapUI进行验证(Alt + V)。如果您正在调试身份验证或其他错误情况,HTTP标头也可能很有用。

class MySoapClient extends SoapClient {
    public function __soapCall ($function_name, array $args, array $options = null, $input_headers = null, array &$output_headers = null) {
        // Dump $args to file, browser printout, console, etc
        var_dump($args);

        parent::__soapCall ($function_name, $args, $options, $input_headers, $output_headers);

        // XML request and response:
        var_dump($this->__getLastRequest()); // Request sent to server
        var_dump($this->__getLastResponse()); // Response from server

        // HTTP headers:
        var_dump($this->__getLastRequestHeaders());
        var_dump($this->__getLastResponseHeaders());
    }

    public function __doRequest ( string $request , string $location , string $action , int $version, int $one_way = 0 ) {
        var_dump($request); // XML

        $response = parent::__doRequest ($request, $location, $action, $version, $one_way);
        var_dump($response); // XML

        return $response;
    }
}

$webservice = new MySoapClient('http://example.com/myservice?wsdl');
$webservice->__soapCall('SomeOperation', array($someArguments));

可以使用记录器代替var_dump:

logger('debug', $this->__getLastRequest());