PHP中soap用法示例【SoapServer服務(wù)端與SoapClient客戶端編寫】
本文實(shí)例講述了PHP中soap用法。分享給大家供大家參考,具體如下:
一、首先要設(shè)置服務(wù)器環(huán)境
修改php.ini
得添加extension=php_soap.dll (加載soap 內(nèi)置包)
修改soap.wsdl_cache_enabled=1 改為soap.wsdl_cache_enabled=0 這個(gè)是soap的緩存,測(cè)試的時(shí)候最好改為0,上線穩(wěn)定了改為1
soap有兩種模式一種是wsdl,一種是no-wsdl
二、熟悉幾個(gè)函數(shù)
1. SoapServer
SoapServer用于創(chuàng)建php服務(wù)器端頁面時(shí)定義可被調(diào)用的函數(shù)及返回 響應(yīng)數(shù)據(jù)
格式:
$soap = new SoapServer($wsdl,$array);
其中,$wsdl為soap使用得wsdl文件,wsdl是描述Web Service的一種 標(biāo)準(zhǔn)格式,若將$wsdl設(shè)置為null,則表示不使用wsdl模式。
$array是 SoapServer的屬性信息,是一個(gè)數(shù)組。
SoapServer對(duì)象的addFunction方法是用來聲明哪個(gè)函數(shù)可以被客戶端調(diào)用, 語法格式如下:
$soap->addFunction($function_name);
其中,$soap是一個(gè)SoapServer對(duì)象,$function_name是需要被調(diào)用的函數(shù)名。
SoapServer對(duì)象的handle方法用來處理用戶輸入并調(diào)用相應(yīng)的函數(shù),最后返回 給客戶端處理的結(jié)果。語法格式如下:
$soap->handle([$soap_request]);
其中,$soap是一個(gè)SoapServer對(duì)象,$soap_request是一個(gè)可選參數(shù),用來表示 用戶的請(qǐng)求信息。如果不指定$soap_request,則表示服務(wù)器將接收用戶的全部 請(qǐng)求。
2. SoapClient
SoapClient用于調(diào)用遠(yuǎn)程服務(wù)器上的SoapServer頁面,并實(shí)現(xiàn)了對(duì)相應(yīng)函數(shù)的調(diào)用
格式:
$soap = new SoapClient($wsdl,$array);
參數(shù)$wsdl和$array與SoapServer相同
SoapClient的方法, 創(chuàng)建語法如下:
$soap->user_function($params);
其中,$soap是一個(gè)SoapClient對(duì)象,user_function是服務(wù)器端要調(diào)用的函數(shù),$params 是要傳入函數(shù)的參數(shù)。
3. SoapFault
SoapFault用于生成soap訪問過程中可能出現(xiàn)的錯(cuò)誤。創(chuàng)建一個(gè)soapFault對(duì)象的語法格式
格式:
$fault = new SoapFault($faultcode,$faultstring);
其中,$faultcode是用戶定義的錯(cuò)誤代碼,$faultstring是用戶自定義的錯(cuò)誤信息。soapFault 對(duì)象會(huì)在服務(wù)器端頁面出現(xiàn)錯(cuò)誤時(shí)自動(dòng)生成,或者通過用戶自行創(chuàng)建SoapFault對(duì)象時(shí)生成。對(duì)于 Soap訪問時(shí)出現(xiàn)的錯(cuò)誤,客戶端可通過捕捉SoapFalut對(duì)象來獲得相應(yīng)的錯(cuò)誤信息。 在客戶端捕獲SoapFault對(duì)象后,可以通過下面的代碼獲得錯(cuò)誤代碼和錯(cuò)誤信息。
$fault->faultcode;//錯(cuò)誤代碼 $fault->faultstring;//錯(cuò)誤信息
其中,$fault是在前面創(chuàng)建的SoapFault對(duì)象。
4. SoapHeader
soapheader用于描述soap的header信息,一般用于認(rèn)證
/* *SoapHeader參數(shù)說明如下所示: *'http://tempuri.org/' namespace(命名空間可省略) *'MySoapHeader' SoapHeader頭的類名 *'array(...)' 存放標(biāo)識(shí)身份的字符串參數(shù) *'true' 是否必須處理該header */
格式:
$h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT);
三、實(shí)例
不用wsdl模式的代碼
服務(wù)端:
//認(rèn)證服務(wù)端
class Test{
public function auth($a)
{
if($a != '123456789'){
throw new SoapFault('Server', '您無權(quán)訪問');
}
}
function say()
{
return 'Hi11111';
}
}
$srv = new SoapServer(null, array('uri' => 'http://192.168.0.153/hao'));
$srv->setClass('Test');
$srv->handle();
Test類中auth是認(rèn)證判斷的,這個(gè)方法對(duì)應(yīng)客戶端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對(duì)應(yīng)服務(wù)端auth方法
如果不 認(rèn)證,可以去掉下面這兩行:
$h = new SoapHeader('http://192.168.0.153/hao/', 'auth', '123456789', false, SOAP_ACTOR_NEXT);
$cli->__setSoapHeaders(array($h));
wsdl模式
首先先生成wsdl文件,至于怎么生成網(wǎng)站很多
服務(wù)端:
//wsdl服務(wù)端
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', '您無權(quán)訪問');
}
}
public function test() {
return 'you are testing';
}
}
客戶端:
//wsdl文件客戶端
$soap = new SoapClient('http://192.168.0.153/hao/server.wsdl'); //如果是遠(yuǎn)程,那當(dāng)然寫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();
}
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php socket用法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》及《PHP網(wǎng)絡(luò)編程技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- Java虛擬機(jī)JVM之server模式與client模式的區(qū)別
- Python Socket實(shí)現(xiàn)簡(jiǎn)單TCP Server/client功能示例
- Android系統(tǒng)進(jìn)程間通信(IPC)機(jī)制Binder中的Server和Client獲得Service Manager接口之路
- python實(shí)現(xiàn)的udp協(xié)議Server和Client代碼實(shí)例
- SQL Server Native Client下載 SQL Server Native Client安裝方法
- 使用Java實(shí)現(xiàn)簡(jiǎn)單的server/client回顯功能的方法介紹
- python client使用http post 到server端的代碼
- Asp.Net 不同的OnClick事件區(qū)別小結(jié)(onserverclick,onclientclick)
- JVM Client和Server端有什么區(qū)別
相關(guān)文章
PHP實(shí)現(xiàn)多服務(wù)器session共享之NFS共享的方法
PHP實(shí)現(xiàn)多服務(wù)器session共享之NFS共享的方法...2007-03-03
php抓取并保存網(wǎng)站圖片的實(shí)現(xiàn)代碼
這篇文章主要介紹了php抓取并保存網(wǎng)站圖片的實(shí)現(xiàn)代碼,網(wǎng)頁源代碼捕獲,圖片鏈接獲取、分析、并將同樣的圖片鏈接合并功能。功能很全面,需要的朋友可以參考下2015-10-10
PHP正則匹配操作簡(jiǎn)單示例【preg_match_all應(yīng)用】
這篇文章主要介紹了PHP正則匹配操作,結(jié)合簡(jiǎn)單實(shí)例形式分析了php中preg_match_all針對(duì)HTML標(biāo)簽中P元素及img src元素內(nèi)容的獲取技巧,需要的朋友可以參考下2017-07-07
PHP中define() 與 const定義常量的區(qū)別詳解
這篇文章主要介紹了PHP中define() 與 const定義常量的區(qū)別,結(jié)合實(shí)例形式分析了php中使用define()與const定義常量的具體使用原理、技巧與相關(guān)用法區(qū)別,需要的朋友可以參考下2019-06-06
PHP中addslashes()和stripslashes()實(shí)現(xiàn)字符串轉(zhuǎn)義和還原用法實(shí)例
這篇文章主要介紹了PHP中addslashes()和stripslashes()實(shí)現(xiàn)字符串轉(zhuǎn)義和還原用法,結(jié)合實(shí)例形式較為詳細(xì)的分析了addslashes()和stripslashes()函數(shù)的功能,定義及具體使用技巧,并附帶說明了addslashes()與addcslashes()函數(shù)的區(qū)別,需要的朋友可以參考下2016-01-01
php 實(shí)現(xiàn)進(jìn)制相互轉(zhuǎn)換
最近的項(xiàng)目中需要用到進(jìn)制轉(zhuǎn)換,這個(gè)問題在剛剛接觸計(jì)算機(jī)理論時(shí)候,還是很會(huì)的,好久不用,居然模糊了……2016-04-04
php curl獲取網(wǎng)頁內(nèi)容(IPV6下超時(shí))的解決辦法
如果開啟了IPv6,curl默認(rèn)會(huì)優(yōu)先解析 IPv6,在對(duì)應(yīng)域名沒有 IPv6 的情況下,會(huì)等待 IPv6 dns解析失敗 timeout 之后才按以前的正常流程去找 IPv42013-07-07

