阿七 |
2006-04-04 14:29 |
作者:heiyeluren 7aTo!T * 时间:2006-03-05 z,XM|-"#<K * 博客:http://blog.csdn.net/heiyeshuwu Qxj &IX n y6-_mA] I^ W
[ Web Service介绍 ] [.tqgU cWIX!tc8 Web Service就是为了异构系统的通信而产生的,它基本的思想就是使用基于XML的HTTP的远程调用提供一种标准的机制,而省去建立一种新协议的需求。目前进行Web Service通信有两种协议标准,一种是XML-RPC,另外一种是SOAP。XML-RPC比较简单,出现时间比较早,SOAP比较复杂,主要是一些需要稳定、健壮、安全并且复杂交互的时候使用。 & i|x2;
v W2
h^ShG PHP中集成了XML-RPC和SOAP两种协议的访问,都是集中在xmlrpc扩展当中。另外,在PHP的PEAR中,不管是PHP 4还是PHP 5,都已经默认集成了XML-RPC扩展,而且该扩展跟xmlrpc扩展无关,能够独立实现XML-RPC的协议交互,如果没有xmlrpc扩展,建议使用PEAR::XML-RPC扩展。 Qg yI\ 我们这里主要是以XML-RPC来简单描述Web Service的交互过程,部分内容来自PHP手册,更详细内容,建议参考手册。 Tysh~C|1 SZJ~ktXC-V \XwXs5"G [ 安装xmlrpc扩展 ] jTk !wm= 2#'{Q4K 如果你的系统中没有安装xmlrpc的php扩展,那么请正确安装。 Er}
xB~<t NwM= 在Windows平台下,首先把PHP安装目录下的扩展php_xmlrpc.dll放到C:\Windows或者C:\Winnt目录下,(PHP4的扩展在C:\php\extensions目录中,PHP5的扩展在C:\php\ext目录中),同时在C:\Windows\php.ini或者C:\Winnt\php.ini中把extension=php_xmlrpc.dll前面的分号";"去掉,然后重启Web服务器后查看phpinfo()有没有XML-RPC项目就能够确定是否已经正确安装xmlrpc扩展。 UMUr"-l = h
&9Ld:p 在Unix/Linux平台下,如果没有安装xmlrpc扩展,请在重新编译PHP,在configure的时候请加入 --with-xmlrpc 选项,然后查看phpinfo()看是否正常安装xmlrpc。 0+IJ, ;Wx ' U{?"FP (注意:以下操作都是建立在xmlrpc扩张正常安装前提下,请务必正确安装。) YhFB*D; M5 ep\^ <jU[&~p [ XML-RPC工作原理 ] UzFd@W u# [La=z7* XML-RPC大致就是整个过程就是使用XML来进行通信。首先构造一个RPC 服务器端用来出来从RPC客户端传递过来的使用XML封装的请求,并且把处理结果通过XML的形式返回给RPC客户端,客户端就去分析XML获取自己需要的数据。 ->&AJI0 2-nL2f!a{p XML-RPC的服务器端必须有现成的函数提供给客户端调用,并且客户端提交的请求中的函数和方法必须和服务器端的一致,否则将无法获取所需要的结果。 "XMTj <D nU%rSASu 下面我进行简单的代码来描述整个过程。 4W}8?&T (.7_`T6QG <QTu"i [ XML-RPC实践 ] Lhu2;F\/ <||F$t 服务器端使用xmlrpc_server_create函数产生一个服务器端,然后把需要需要暴露的RPC调用接口进行注册,接受RPC客户端POST过来的XML数据,然后进行处理,处理结果通过XML的形式显示给客户端。 @5Q}o3.zA- /lDW5
;d 代码如下: rpc_server.php ^sd+s ~xx zAt!jP0E <?php b")&"o)G2W /** Fgxh?Wd9 * 函数:提供给RPC客户端调用的函数 ~\DC
) * 参数: {4ON2{8;4 * $method 客户端需要调用的函数 EaFd1 * $params 客户端需要调用的函数的参数数组 VkhZt7]K}B * 返回:返回指定调用结果 T^S|u8f */ R+8+L|\wHv function rpc_server_func($method, $params) { 016l$K4 $parameter = $params[0]; ;r>?V2,tm if ($parameter == "get") =1)yI>2e%} { 8qp!S1Qnv $return = 'This data by get method'; nCh9IF[BL/ }
4?g~GI3 else tc\LK_@$/F { k!t5>kPSQ $return = 'Not specify method or params'; REB8_H" } a+szA}; return $return; r^_8y8&l } AvRZf-Geg 6(B0gBCId //产生一个XML-RPC的服务器端 oh%T4$ $xmlrpc_server = xmlrpc_server_create(); HnU
M:-6 }lML..((1 //注册一个服务器端调用的方法rpc_server,实际指向的是rpc_server_func函数 ?Ri
W:TQ* xmlrpc_server_register_method($xmlrpc_server, "rpc_server", "rpc_server_func"); qD7(+a *:\-:* //接受客户端POST过来的XML数据 9 }|Bs=q $request = $HTTP_RAW_POST_DATA; 5*[zIKdt2 LPb43 //执行调用客户端的XML请求后获取执行结果 ,~X^8oY $xmlrpc_response = xmlrpc_server_call_method($xmlrpc_server, $request, null); M3K+;-n^ [{6]i
J //把函数处理后的结果XML进行输出 UY*Hc header('Content-Type: text/xml'); Hlp!6\gukp echo $xmlrpc_response; RZjTUMAz4 kR7IZo"q //销毁XML-RPC服务器端资源 Ig"Krz xmlrpc_server_destroy($xmlrpc_server); pwT|T;j* ?> -5>K
pgXo\ jkQv cU 服务器端构造好了,那么再构造我们的RPC客户端。客户端大致通过Socket访问XML-RPC服务器端的80端口,然后把需要调用的RPC接口封装到XML里,通过POST请求提交给RPC服务器端,最后获取服务器端返回结果。 Ko\m8\3?fK 6|X 代码如下:rpc_client.php lEQ63)Z Ec8Y}C,{7< <?php BqvOi
~l /** FfI$3:9 * 函数:提供给客户端进行连接XML-RPC服务器端的函数 j +@1frp * 参数: 7`6n]4e * $host 需要连接的主机 S-gL]r3G8 * $port 连接主机的端口 ;Y?7|G97*S * $rpc_server XML-RPC服务器端文件 R)WvU4+U * $request 封装的XML请求信息 *ls}r5k2Y * 返回:连接成功成功返回由服务器端返回的XML信息,失败返回false 92]>" */ {{ R/:-6?@ function rpc_client_call($host, $port, $rpc_server, $request) { QJTGeJ
Y ~/!Zh //打开指定的服务器端 q!7z4Cn $fp = fsockopen($host, $port); P}~6y
X Rde#=>@V //构造需要进行通信的XML-RPC服务器端的查询POST请求信息 kFHqQsaG $query = "POST $rpc_server HTTP/1.0\nUser_Agent: XML-RPC Client\nHost: ".$host."\nContent-Type: text/xml\nContent-Length: ".strlen($request)."\n\n".$request."\n"; 1FjA Nj %!N //把构造好的HTTP协议发送给服务器,失败返回false 9^4^EY# if (!fputs($fp, $query, strlen($query))) KG'4;Z5J { Kk!D|NKLC $errstr = "Write error"; m qPWCFP return false; *P$5k1 } -/~^S] Fr,>| //获取从服务器端返回的所有信息,包括HTTP头和XML信息 =NSLx2:T $contents = ''; HGC>jeWd_ while (!feof($fp)) GTYGm { |LcN_,}6 $contents .= fgets($fp); KB&t31aq } Pgr>qcbql JR$Dp&]I //关闭连接资源后返回获取的内容 NrgN{6u; fclose($fp); 59$mfW
o> return $contents; b&*^\hY9b } 6}L[7~1
2OAh7'8< //构造连接RPC服务器端的信息 VaZS_qGe: $host = 'localhost'; hNyYk(t^ $port = 80; nDiD7:e7= $rpc_server = '/~heiyeluren/rpc_server.php'; M7e
O5 WyA>OB<Zeq //把需要发送的XML请求进行编码成XML,需要调用的方法是rpc_server,参数是get X~P0Q $request = xmlrpc_encode_request('rpc_server', 'get'); Gw~^6(Qu cP$b>3O //调用rpc_client_call函数把所有请求发送给XML-RPC服务器端后获取信息 ^(N+s? $response = rpc_client_call($host, $port, $rpc_server, $request); k1$|vzMh k:m~'r8z
//分析从服务器端返回的XML,去掉HTTP头信息,并且把XML转为PHP能识别的字符串 S?OK@UEJ $split = '<?xml version="1.0" encoding="iso-8859-1"?>'; @K4} cP $xml = explode($split, $response); ,BW^j.7 $xml = $split . array_pop($xml); ^5 F-7R8Q $response = xmlrpc_decode($xml); EK@yzJ% H#m)`=nZSZ //输出从RPC服务器端获取的信息 H<}<f: print_r($response); :n0(gB +3si=x\=/ ?> '3[Ecy# &^ =t%A%# asQ pVP 大致我们上面的例子就是提交一个叫做rpc_server的方法过去,参数是get,然后获取服务器端的返回,服务器端返回的XML数据是: TkWS-=lNH0 u5
V<f; <?xml version="1.0" encoding="iso-8859-1"?> ?F
AsV&y <methodResponse> eU@yw1N <params> Z:O24{ro5 <param> kzJNdYtdH <value> ^w8H=UkP!+ <string>This data by get method</string> LP@Q8{' </value> cX7xG U </param> >9+@oGe(E </params> b[GZ sXD- </methodResponse> [%P_
Y/ D*vrQ9&#
8 那么我们再通过xmlrpc_decode函数把这个XML编码为PHP的字符串,我们就能够随意处理了,整个Web Service交互完成。 4{CVBowi 6by5V
ESx w gATfyg
r [ 结束语 ] ;?=] ffa{ ORcl=Eo> 不管是XML-RPC也好,SOAP也罢,只要能够让我们稳定、安全的进行远程过程的调用,完成我们的项目,那么就算整个Web Service就是成功的。另外,如果可以的话,也可以尝试使用PEAR中的XML-RPC来实现上面类似的操作,说不定会更简单,更适合你使用。 W>wE8? _, <G2;nvRr 简单的使用XML-RPC进行Web Service交互就完成了,部分代码参考PHP手册,想获取详细信息建议参考手册,如果文章有不正确,请指正。 uPRusG4!R G
A2S e_k1pox]l heiyeluren a3R#Bg( write by 2006-3-5 下午 18:00 |
|