在第三方库中记录SOAP信封

时间:2015-09-02 00:45:35

标签: php soap envelope

我正在尝试为第三方库生成的信封添加日志记录。我正在修改下面的updateMetadataField()方法。

我正在创建$ client:

$client = new UpdateClient($UPDATE_END_POINT, $USER_AUTH_ARRAY);

我已尝试使用$this->client->__getLastRequest()$this->__getLastRequest()同样的错误。

实例化SoapClient时,trace设置为true

错误是

Fatal error:  Call to undefined method UpdateClient::__getLastRequest() 

那么如何正确访问__getLastRequest()方法?

$USER_AUTH_ARRAY = array(
    'login'=>"foo",
    'password'=>"bar",
    'exceptions'=>0,
    'trace'=>true,
    'features' => SOAP_SINGLE_ELEMENT_ARRAYS
);

class UpdateClient {
    private $client;

    public function __construct($endpoint, $auth_array) {
        $this->client = new SoapClient($endpoint, $auth_array);
    }

    public function updateMetadataField($uuid, $key, $value) {
        $result = $this->client->updateMetadataField(array(
            'assetUuid' =>  $uuid, 
            'key' =>        $key,
            'value' =>      $value)
        );

        if(is_soap_fault($result)) {
            return $result;
        }

        return $result->return . "\n\n" . $this->client->__getLastRequest();

    } // updateMetadataField()

} // UpdateClient

更新 - 添加调用代码此代码遍历将数据映射到远程字段的数组。

我希望做的是开始存储我们发送的信封以帮助调试。

    $client = new UpdateClient($UPDATE_END_POINT, $USER_AUTH_ARRAY);
    foreach ($widen_to_nool_meta_map as $widen => $nool) { // array defined in widen.php
        if ($nool != '') {
            // handle exceptions
            if ($nool == 'asset_created') { // validate as date - note that Widen pulls exif data so we don't need to pass this
                if (!strtotime($sa->$nool)) {
                    continue;   
                }
            } else if ($nool == 'people_in_photo' || $nool == 'allow_sublicensing' || $nool == 'allowed_use_pr_gallery') {  
                // we store as 0/1 but GUI at Widen wants Yes/No
                $sa->$nool = ($sa->$nool == '1') ? 'Yes' : 'No';
            } else if ($nool == 'credit_requirements') {
                $sa->$nool = $sa->credit_requirements()->label;
            }

            $result = $client->updateMetadataField($sa->widen_id, $widen, $sa->$nool);
            if(is_soap_fault($result)) {    
                $sync_result    = $sync_result . "\n" . $result->getMessage();
            } else {
                $sync_result    = $sync_result . "\n" . print_r($result, 1);
            }
        } // nool field set         
    } // foreach mapped field

1 个答案:

答案 0 :(得分:2)

如果要访问UpdateClient::__getLastRequest(),则必须在UpdateClient类上公开该方法,因为$ client是一个私有变量。调用它的正确方法是$this->client->__getLastRequest()

请看一下这个工作示例,因为您可以看到我正在使用免费的Web服务进行测试。

<?php
$USER_AUTH_ARRAY = array(
    'exceptions'=>0,
    'trace'=>true,
    'features' => SOAP_SINGLE_ELEMENT_ARRAYS
);

class TestClient {
    private $client;

    public function __construct($endpoint, $auth_array) {
        $this->client = new SoapClient($endpoint, $auth_array);
    }

    public function CelsiusToFahrenheit( $celsius ) {
        $result = $this->client->CelsiusToFahrenheit(array(
            'Celsius' =>  $celsius
            )
        );

        if(is_soap_fault($result)) {
            return $result;
        }

        return $result;

    }

    public function __getLastRequest() {
        return $this->client->__getLastRequest();
    }

} 

try 
{
    $test = new TestClient( "http://www.w3schools.com/webservices/tempconvert.asmx?wsdl", $USER_AUTH_ARRAY);
    echo "<pre>";
    var_dump($test->CelsiusToFahrenheit( 0 ));
    var_dump($test->__getLastRequest());
    var_dump($test->CelsiusToFahrenheit( 20 ));
    var_dump($test->__getLastRequest());
    echo "</pre>";
} 
catch (SoapFault $fault) 
{ 
    echo $fault->faultcode;
}
?>