1

監視ステーションから水位を取得するために、phpのsoapClientを介してWebサービスにSOAP呼び出しを行うことに興味があります。実行中に発生した2つのsoapfaultを処理したいと思います。最初の障害は次のとおりです。

SoapFault exception: [soapenv:Server.userException] java.rmi.RemoteException: We are sorry, but no data is available from this station at this time in C:\xampp\htdocs\NOAA\LogWriter.php:214 Stack trace: #0 C:\xampp\htdocs\NOAA\LogWriter.php(214): SoapClient->__soapCall('getWaterLevelRa...', Array, Array) #1 C:\xampp\htdocs\NOAA\LogWriter.php(188): getLevel('8531680', '20120726 15:19') #2 {main}

このエラーは、特定の時間のデータが利用できない場合、スクリプト中に数回発生することが予想されます。スクリプトに新しい時刻で再試行するように指示するには、この障害をキャッチする必要があります。私はそうするためにキャッチブロックを使用しました。

また、Webサービスがwsdlファイルをロードしていない場合、またはサーバーがタイムアウトした場合に発生する2番目の障害をキャッチする必要があります。これをテストするために、以前に受け取ったのと同じエラーを生成するための誤った場所がスクリプトに与えられました。これは次のとおりです。

Fatal error: Uncaught SoapFault exception: [WSDL] SOAP-ERROR: Parsing WSDL: Couldn't load from 'http://opendap.co-ops.nos.noaa.gov/axis/services/WaterLevelRawOneMin?wsdl' : Extra content at the end of the document in C:\xampp\htdocs\NOAA\LogWriter.php:210 Stack trace: #0 C:\xampp\htdocs\NOAA\LogWriter.php(210): SoapClient->SoapClient('http://opendap....', Array) #1 C:\xampp\htdocs\NOAA\LogWriter.php(171): getLevel('8531680', '20120726 12:35') #2 {main} thrown in C:\xampp\htdocs\NOAA\LogWriter.php on line 210  

2番目のエラーは捕捉されず、スクリプトが終了します。しかし、私はそれをキャッチしてメッセージを表示する必要があります。

以下にsoap呼び出しを行うphp関数を投稿しました。

誰かが私にこれを行う方法について何かアイデアを教えてもらえますか?

function getLevel($id, $date) {

    $client = new SoapClient("http://opendap.co-ops.nos.noaa.gov/axis/services/WaterLevelRawOneMin?wsdl", array('trace' => false));

    $Parameters = array("stationId" => $id, "beginDate" => $date, "endDate" => $date, "datum" => "MLLW",
                        "unit"      => 1, "timeZone" => 1);

    try {
        return $client->__soapCall(
            "getWaterLevelRawOneMin", array('Parameters' => $Parameters),
            array('location' => "http://opendap.co-ops.nos.noaa.gov/axis/services/WaterLevelRawOneMin")
        );
    } catch (SoapFault $e) {
        if (
            $e->faultcode == "soapenv:Server.userException"
            and $e->faultstring == "java.rmi.RemoteException: We are sorry, but no data is available from this station at this time"
        ) {
            return "FAULT";
        } else {
            echo "Could not connect to the server";
        }
    } // end of catch blocK
}// end of function
4

1 に答える 1

1

壊れた WSDL に関する例外は、SoapClient::constructor を呼び出した場合にのみ発生する可能性があるため、

try {
    $client= new SoapClient($wsdlUrl ,array('trace'=>false));
}catch(Exception $e) {
    // your loging regarding this case 
}

Web サービスを作成すると、SoapFault 例外が発生する可能性があります。

try {
    $client= new SoapClient($wsdlUrl ,array('trace'=>false));
    try {
       return $client->_call('....');
    } catch (SoapFault $sp) {
        //your logic rearding soap fault 
    }
}catch(Exception $e) {
    // your loging regarding this case 
}
return false;
于 2012-07-27T00:05:12.977 に答える