本人所了解的webservice有以下幾種:PHP本身的SOAP,開源的NUSOAP,商業版的PHPRPC,以及使用二進制傳輸數據流的HessianPHP,那么一下就簡單的介紹下這幾種webservice在php中的使用,雖然網上也有很多這方面的資料,但是這是我個人實踐所得,當然也是從網上找的資料,在此簡單的做個筆記。
一:PHP本身的SOAP
所有的webservice都包括服務端(server)和客戶端(client)。
要使用php本身的soap首先要把該拓展安裝好並且啟用。下面看具體的code
首先這是服務端實現:
<?php class test { function show() { return 'the data you request!'; } } function getUserInfo($name) { return 'fbbin'; } //實例化的參數手冊上面有,這個是沒有使用wsdl的,所以第一個參數為null,如果有使用wsdl,那么第一個參數就是這個wsdl文件的地址。 $server = new SoapServer(null, array('uri' ='http://soap/','location'='http://localhost/test/server.php')); $server->setClass('test'); //$server->addFunction('getUserInfo'); $server->handle(); ?>
然后是客戶端
$soap = new SoapClient(null, array('location'='http://localhost/test/server.php','uri' ='http://soap/')); echo $soap->show(); //得到:'the data you request!' //echo $soap->getUserInfo('sss');
就這么簡單,當時這只是一個很簡單的例子,其實很多的通信機制都是這么去實現的!
////////////////////////////////////////////////////////////////////////////////
二:PHPRPC
首先到官網(http://www.phprpc.org/zh_CN/ )上面去下載最新版的phprpc,解壓之后會有相關的文件,我們把文件進行划分(服務端和客戶端文件)如下:
服務端文件:
dhparams dhparams.php phprpc_server.php bigint.php compat.php phprpc_date.php xxtea.php
客戶端文件:
phprpc_client.php bigint.php compat.php phprpc_date.php xxtea.php
我們把服務端文件放在服務端文件夾中,然后把客戶端文件放在客戶端文件夾中,之后再服務端文件夾中新建個文件(server.php)作為服務,然后再客戶端新建個文件(client.php)作為客戶端,各自代碼如下:
server端:
<?php include_once"phprpc_server.php"; //加載phprpc文件 $server = new PHPRPC_Server(); $server->add('getUser'); $server->setDebugMode(true); $server->start(); function getUser( ) { return ‘the data you request!’; } client端: [code] <?php include_once "phprpc_client.php"; $client = new PHPRPC_Client('http://127.0.0.1/phpservice/phprpcserver/server.php'); $data = $client->getUser(); var_dump($data); //得到:the data you request!
這上面提到wsdl之后會講到如何生成。
三:開源的NUSOAP
首先到網上去下載最新版的nusoap,現在的最新版本是0.9.5的,解壓之后會得到一個lib文件夾,把這個文件分別放到服務端和客戶端各一份,然后再服務端和客戶端分別建立server.php和client.php文件,作為通信文件。
服務端文件如下:
<?php ini_set("soap.wsdl_cache_enabled", 0);//關閉緩存 require_once("lib/nusoap.php"); //加載nusoap文件 $server = new soap_server; $server->configureWSDL('nusoasp');//設定服務的名稱,使用的wsdl來通信,如果不適用wsdl將會更簡單,網上有很多的例子 $server->register('getUserInfo', array('name'="xsd:string", 'email'="xsd:string"), array('return'="xsd:string")); $HTTP_RAW_POST_DATA = isset($HTTP_RAW_POST_DATA) ? $HTTP_RAW_POST_DATA : ''; $server->service( $HTTP_RAW_POST_DATA ); function getUserInfo($name, $email) { return ‘the data you request!’; }
客戶端文件如下:
require_once("lib/nusoap.php"); $client = new soapclient('http://localhost/phpservice/nusoapserver/server.php?wsdl'); $pagram = array('fbbin', 'fbbin@foxmail.com'); $string = $client->call('getUserInfo', $pagram); //得到:the data you request!
四:HessianPHP
hessian其實我個人認為他不是一個webservice,只能說是類似而已。因為它不具備webservice的那些特性。它支持的語言比較多我們現在只需要研究php版本的HessianPHP就行了,下載最新版本是v2.0.3的,解壓之后會得到一個src的目錄,這個目錄使我們需要使用的一個核心文件夾。
我們把名字重命名為HessianPHP然后分別分別放到server和client端,然后分別建立server.php和client.php文件。
server端:
<?php include_once 'HessianPHP/HessianService.php';//加載核心文件 class TestService { public function __construct() { } public function add($numa, $numb) { return $numa + $numb; } public function check() { return 'fbbiin@gmail.com'; } } $test = new TestService(); $hessian = new HessianService( $test, array('displayInfo' => true) ); $hessian->handle();//注意這里不是網上的$hessian->service(),可能是版本不一樣,改了吧!我也是看了源碼才知道! ?>
client 端:
<?php include_once 'HessianPHP/HessianClient.php'; $url = "http://localhost/phpservice/hessianserver/server.php"; $options = new HessianOptions(); $client = new HessianClient( $url, $options ); $num = $client->add( 3, 5 ); echo $num;//得到:8; echo $client->check();//得到:fbbiin@gmail.com;
以上四種方式為web開發過程中常用到的webservice通信方式。用的最多的是nusoap,個人感覺phprpc其實也不錯,這個在性能上面和nusoap基本上差不多,只不過,phprpc在商業上是收費的。還有個hessianPHP好像是用java的,采用的二進制方式傳輸數據流,其實也是各有千秋啊。更多的詳細資料去找百度和谷歌吧。
下面說下生成wsdl文件。
我們在webservice上面進行通信用的最多的和相對來說比較安全的就是使用wsdl了,這種文件可以自己書寫,但是不是一定的大牛好像寫不出來啊,因此我們需要借助一個工具zend studio來生成wsdl文件。
下面我們就來生成WSDL文件了,File->New—>Other—>Web Service—>WSDL,這樣就可以新建一個WSDL文件了,如圖。
然后我們就來修改WSDL文件,zeng studio為我們提供了可視化的操作,當然如果你牛的話,你當然是可以改文件代碼的,其實也就幾個東西, 弄懂了的話也不會太難。
做完這一步,這個WSDL文件就基本可用了,但又兩個問題需要注意:
做到這一步,有可能會測試失敗,可能會因為沒有進行binding,這個東西有時是需要手動來完成的,在binding上右鍵選擇Generate Binding Content(就是兩個大框中間那個小框)就行了。
第二個要注意的是php的WSDL緩存,在做測試時,一般要將WSDL緩存關閉,否則你使用的有可能是原來的WSDL文件,而不是更新過的。關閉緩存有兩種方法,第一種就是直接到php.ini中設置soap.wsdl_cache_enabled = 0;第二種就是在php文件中添加一條語句,ini_set("soap.wsdl_cache_enabled", "0");
做到這里,你就可以放心地測試,調用你的server程序了。
說完了,OK!
資料參考:
1:http://winphfar.iteye.com/blog/559347;
2:http://www.iteye.com/blogs/tag/phprpc
3:http://yeyuan.iteye.com/blog/1261491
4:http://www.cnblogs.com/helloxyz/archive/2011/11/5.html
5:http://www.phpx.com/happy/thread-122030-1-1.html