如何查看由PHP SOAP客户机类生成的实际XML?

考虑这个示例SOAP客户端脚本:

$SOAP = new SoapClient($WDSL); // Create a SOAP Client from a WSDL // Build an array of data to send in the request. $Data = array('Something'=>'Some String','SomeNumber'=>22); $Response = $SOAP->DoRemoteFunction($Data); // Send the request. 

在最后一行,PHP从您指定的数组中获取参数,然后使用WSDL构build发送的XML请求,然后发送它。

我如何让PHP向我展示它构build的实际XML?

我正在对应用程序进行故障诊断,并需要查看请求的实际XML。

使用getLastRequest 。 它返回在最后的SOAP请求中发送的XML。

 echo "REQUEST:\n" . $SOAP->__getLastRequest() . "\n"; 

请记住,只有在trace选项设置为TRUE下创buildSoapClient对象,此方法才有效。 因此,在创build对象时,请使用以下代码:

 $SOAP = new SoapClient($WDSL, array('trace' => 1)); 
 $SOAP = new SoapClient($WSDL, array('trace' => true)); $Response = $SOAP->DoRemoteFunction($Data); echo "REQUEST:\n" . htmlentities($SOAP->__getLastRequest()) . "\n"; 

这将不会打印最后一个请求,但也使浏览器中可见的XML标签

如果您希望查看请求而不实际build立连接,则可以覆盖SoapClient的__doRequest方法以返回XML:

 class DummySoapClient extends SoapClient { function __construct($wsdl, $options) { parent::__construct($wsdl, $options); } function __doRequest($request, $location, $action, $version, $one_way = 0) { return $request; } } $SOAP = new DummySoapClient('http://example.com/?wsdl', array('trace' => true)); echo $SOAP->GetRequestDetail($params); 

扩展奎因的答案,您也可以在执行请求之前logging请求。

 class SoapClientDebug extends SoapClient { public function __doRequest($request, $location, $action, $version, $one_way = 0) { error_log("REQUEST:\n" .$request . "\n"); error_log("LOCATION:\n" .$location . "\n"); error_log("ACTION:\n" .$action . "\n"); error_log("VERSION:\n" .$version . "\n"); error_log("ONE WAY:\n" .$one_way . "\n"); return parent::__doRequest($request, $location, $action, $version, $one_way); } } 

您需要在创buildSoapClient时启用跟踪。 像这样:

 $SOAP = new SoapClient($WSDL, array('trace' => true)); $Data = array('Something'=>'Some String','SomeNumber'=>22); 

然后在调用服务之后调用__getLastRequest方法来查看XML。

 $Response = $SOAP->DoRemoteFunction($Data); echo $SOAP->__getLastRequest(); 

这将输出请求XML。

更多阅读: http : //www.php.net/manual/en/soapclient.getlastrequest.php

如果你正在本地运行客户端, Fiddler是一个很好的实现不可知的方式来查看线路上的消息。

如果你正在远程运行,那么你可以使用像Apache TCPMON Standalone或通过eclipse *

*只是链接到谷歌的第一击

Quinn Comendant的答案是, __doRequest() $request将被__call()处理,用户将看到一个参数数组,而不是真正的xml请求。 为了防止这种情况,可以使用这种解决方法:

 class DummySoapClient extends SoapClient { function __construct($wsdl, $options) { parent::__construct($wsdl, $options); } function __doRequest($request, $location, $action, $version, $one_way = 0) { throw new Exception($request); } function __call($function_name, $arguments) { try { parent::__call($function_name, $arguments); } catch (Exception $e) { return $e->getMessage(); } } } 

选项trace在这里没有必要,因为我们不调用__getLastRequest()或其他相关函数。