4

我正在使用 UPS api 并且很难调试。我得到以下堆栈跟踪:

Details
Type: SoapFault
Message: An exception has been raised as a result of client data.
File: /Users/shawn/Documents/work/sites/Wingspan/kaleco/lib/SixString/Utilities/Ups.php
Line: 161
Trace

#0 /Users/shawn/Documents/work/sites/Wingspan/kaleco/lib/SixString/Utilities/Ups.php(161): SoapClient->__soapCall('ProcessShipment', Array)
#1 /Users/shawn/Documents/work/sites/Wingspan/kaleco/routes/ups.php(14): SixString\Utilities\Ups->getShipment()
#2 [internal function]: {closure}()
#3 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Router.php(172): call_user_func_array(Object(Closure), Array)
#4 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Slim.php(1222): Slim\Router->dispatch(Object(Slim\Route))
#5 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Middleware/Flash.php(86): Slim\Slim->call()
#6 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Middleware/MethodOverride.php(94): Slim\Middleware\Flash->call()
#7 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Middleware/SessionCookie.php(116): Slim\Middleware\MethodOverride->call()
#8 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Middleware/PrettyExceptions.php(67): Slim\Middleware\SessionCookie->call()
#9 /Users/shawn/Documents/work/sites/Wingspan/kaleco/vendor/slim/slim/Slim/Slim.php(1174): Slim\Middleware\PrettyExceptions->call()
#10 /Users/shawn/Documents/work/sites/Wingspan/kaleco/public/index.php(6): Slim\Slim->run()
#11 {main}

这是代码块:

    try{
        $mode = array('soap_version' => 'SOAP_1_1',  'trace' => 1,'exceptions' => true );
        $client = new \SoapClient($wsdl , $mode);
        $client->__setLocation($endpointurl);

        $header = new \SoapHeader('http://www.ups.com/XMLSchema/XOLTWS/UPSS/v1.0','UPSSecurity',$this->upss);
        $client->__setSoapHeaders($header);

        if(strcmp($operation,"ProcessShipment") == 0 ) {
            $resp = $client->__soapCall('ProcessShipment',array($this->processShipment()));
            echo "Response Status: " . $resp->Response->ResponseStatus->Description ."\n";
            //print_r($client->__getLastRequest());
        }
        else if (strcmp($operation , "ProcessShipConfirm") == 0) {
            $resp = $client->__soapCall('ProcessShipConfirm',array($this->processShipConfirm()));
            echo "Response Status: " . $resp->Response->ResponseStatus->Description ."\n";
        }
        else {
            $resp = $client->__soapCall('ProcessShipeAccept',array($this->processShipAccept()));
            //get status
            echo "Response Status: " . $resp->Response->ResponseStatus->Description ."\n";
            echo "<pre>";
            print_r($resp);
            echo "</pre>";
        }
    }
    catch(Exception $ex){
        print_r ($ex);
    }

第 161 行在上面的代码中,这是实际的行:

$resp = $client->__soapCall('ProcessShipConfirm',array($this->processShipConfirm()));

我正在寻找一种调试方法。它似乎没有到达catch障碍,我似乎无法确定异常的原因。

4

4 回答 4

4

尝试捕获异常SoapFault并打印其detail属性。

try {

   $response = $client->$call( $params );

} catch (\SoapFault $fault) {

    //trigger_error("SOAP Fault: (faultcode: {$fault->faultcode}, faultstring: {$fault->faultstring})", E_USER_ERROR);
    var_dump($fault->faultcode);
    var_dump($fault->faultstring);
    var_dump($fault->detail);
    die('Errore chiamata webservice UPS');

}

参考: http: //php.net/manual/en/function.is-soap-fault.php

于 2016-02-23T10:53:08.330 回答
1

注意:对于它的价值,UPS 会为错误的跟踪号码提供此错误。使用一个好的(有效的)跟踪号,它纠正了我的问题。

于 2014-05-15T14:44:29.273 回答
1

我不知道 PHP 中异常处理的细微差别,但 Soap 异常也是 C# 中的小虫子。在 Visual Studio 的调试器中,您可以直接在 IDE 中获取未处理异常的详细信息。如果您可以选择执行此操作,请查找异常的"detail"XML 元素,因为这将包含 Web 服务的消息,告诉您您的请求有什么问题。

至于实际捕获异常,@Jeff Atwood 有一篇古老但很好的文章——尽管是为(喘气)VB.NET 编写的——可能仍然可以提供一些关于导致 Soap 异常的原因的一些见解,呃......滑:编码恐怖 | 抛出更好的 SOAP 异常

于 2013-09-04T20:47:42.220 回答
1

对于 Rates API 中的错误 ShipFrom/CountryCode 或 ShipTo/CountryCode,UPS 也会给出此错误。例如,德国无法评级。这在 UPS 开发文档中找不到。

于 2014-09-05T12:55:28.543 回答