監視ステーションから水位を取得するために、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