分享php中四種webservice實現的簡單架構方法及例項
本人所瞭解的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', '[email protected]');
$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 '[email protected]';
}
}
$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();//得到:[email protected];
以上四種方式為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