一,首先要設置服務器環境。
修改php.ini
得添加extension=php_soap.dll (加載soap 內置包)
修改soap.wsdl_cache_enabled=1 改成soap.wsdl_cache_enabled=0 這個是soap的緩存,測試的時候最好改成0,上線穩定了改成1php
soap有兩種模式一種是wsdl,一種是no-wsdlweb
// WSDL模式 $wsdlUrl = 'http://www.aisinogz.com:19876/AisinoFp-test/eliWebService.ws?wsdl'; $params = array('track' => 1); $client = new SoapClient($wsdlUrl, $params = null); $methodParams = array(); // 爲請求的參數,根據數據結構填寫 try { $resoponse = $client->method($methodParams); var_dump($response); file_put_contents('./log.txt', $client->__getLastRequest()); } catch (SoapFault $e) { print($e->getMessage); file_put_contents('./log.txt', $client->__getLastRequest()); } // non-WSDL模式 $params = array('location' => 'http://www.aisinogz.com:19876/AisinoFp-test/eliWebService.ws', 'uri' => 'http://webservice.companyInterface.dzfp.fp.aisinogd.com', 'trace' => 1); // location爲不帶?wsdl的地址,uri爲targetNamespace $client = new SoapClient(null, $params = null); $methodParams = array(); // 爲請求的參數,根據數據結構填寫 try { $resoponse = $client->__soapCall(method, $methodParams); var_dump($response); file_put_contents('./log.txt', $client->__getLastRequest()); } catch (SoapFault $e) { print($e->getMessage); file_put_contents('./log.txt', $client->__getLastRequest()); }
二,熟悉幾個函數數組
1,SoapServer緩存
SoapServer用於建立php服務器端頁面時定義可被調用的函數及返回 響應數據服務器
格式:$soap = new SoapServer($wsdl,$array);
其中,$wsdl爲soap使用得wsdl文件,wsdl是描述Web Service的一種 標準格式,若將$wsdl設置爲null,則表示不使用wsdl模式。數據結構
$array是 SoapServer的屬性信息,是一個數組。函數
SoapServer對象的addFunction方法是用來聲明哪一個函數能夠被客戶端調用, 語法格式以下:
$soap->addFunction($function_name);
其中,$soap是一個SoapServer對象,$function_name是須要被調用的函數名。
SoapServer對象的handle方法用來處理用戶輸入並調用相應的函數,最後返回 給客戶端處理的結果。語法格式以下:
$soap->handle([$soap_request]);
其中,$soap是一個SoapServer對象,$soap_request是一個可選參數,用來表示 用戶的請求信息。若是不指定$soap_request,則表示服務器將接收用戶的所有 請求。 測試
2,SoapClient網站
SoapClient用於調用遠程服務器上的SoapServer頁面,並實現了對相應函數的調用 ui
格式:$soap = new SoapClient($wsdl,$array);
參數$wsdl和$array與SoapServer相同
SoapClient的方法, 建立語法以下:
$soap->user_function($params);
其中,$soap是一個SoapClient對象,user_function是服務器端要調用的函數,$params 是要傳入函數的參數。
3,SoapFault
SoapFault用於生成soap訪問過程當中可能出現的錯誤。建立一個soapFault對象的語法格式
格式:$fault = new SoapFault($faultcode,$faultstring);
其中,$faultcode是用戶定義的錯誤代碼,$faultstring是用戶自定義的錯誤信息。soapFault 對象會在服務器端頁面出現錯誤時自動生成,或者經過用戶自行建立SoapFault對象時生成。對於 Soap訪問時出現的錯誤,客戶端可經過捕捉SoapFalut對象來得到相應的錯誤信息。 在客戶端捕獲SoapFault對象後,能夠經過下面的代碼得到錯誤代碼和錯誤信息。
$fault->faultcode;//錯誤代碼
$fault->faultstring;//錯誤信息
其中,$fault是在前面建立的SoapFault對象。
4,SoapHeader
soapheader用於描述soap的header信息,通常用於認證
/*
*SoapHeader參數說明以下所示:
*'http://tempuri.org/' namespace(命名空間可省略)
*'MySoapHeader' SoapHeader頭的類名
*'array(...)' 存放標識身份的字符串參數
*'true' 是否必須處理該header
*/
格式:$h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT);
三,實例
不用wsdl模式的代碼
服務端:
//認證服務端 class Test{ public function auth($a) { if($a != '123456789'){ throw new SoapFault('Server', '您無權訪問'); } } function say() { return 'Hi11111'; } } $srv = new SoapServer(null, array('uri' => 'http://192.168.0.153/hao')); $srv->setClass('Test'); $srv->handle();
Test類中auth是認證判斷的,這個方法對應客戶端soapheader中的方法
客戶端:
//加密的客戶端 $cli = new SoapClient(null, array('uri' => 'http://192.168.0.153/hao/', 'location' => 'http://192.168.0.153/hao/test.php', 'trace' => true,'encoding'=>'utf-8')); $h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT); $cli->__setSoapHeaders(array($h)); try { echo $cli->say(); } catch (Exception $e) { echo $e->getMessage(); }
soapheader中auth對應服務端auth方法
若是不 認證,能夠去掉下面這兩行:
$h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT);
$cli->__setSoapHeaders(array($h));
wsdl模式
首先先生成wsdl文件,至於怎麼生成網站不少
服務端:
//wsdl服務端 Require './server.class.php'; $server = new SoapServer('./server.wsdl'); $server->setClass('Server'); $server->handle();
server.class.php類代碼
class Server { public function auth($a){ if($a != '123456789'){ throw new SoapFault('Server', '您無權訪問'); } } public function test() { return 'you are testing'; } }
客戶端:
//wsdl文件客戶端 $soap = new SoapClient('http://192.168.0.153/hao/server.wsdl'); //若是是遠程,那固然寫dizzylion.wsdl的URL了。 $h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT); $soap->__setSoapHeaders(array($h)); try { echo $soap->test(); } catch (Exception $e) { echo $e->getMessage(); }