php xmlrpc的简单实用

[ Web Service介绍 ]
Web Service就是为了异构系统的通信而产生的,它基本的思想就是使用基于XML的HTTP的远程调用提供一种标准的机制,而省去建立一种新协议的需求。目前进行Web Service通信有两种协议标准,一种是XML-RPC,另外一种是SOAP。XML-RPC比较简单,出现时间比较早,SOAP比较复杂,主要是一些需要稳定、健壮、安全并且复杂交互的时候使用。
PHP中集成了XML-RPC和SOAP两种协议的访问,都是集中在xmlrpc扩展当中。另外,在PHP的PEAR中,不管是PHP 4还是PHP 5,都已经默认集成了XML-RPC扩展,而且该扩展跟xmlrpc扩展无关,能够独立实现XML-RPC的协议交互,如果没有xmlrpc扩展,建议使用PEAR::XML-RPC扩展。
我们这里主要是以XML-RPC来简单描述Web Service的交互过程,部分内容来自PHP手册,更详细内容,建议参考手册。
[  安装xmlrpc扩展 ]
如果你的系统中没有安装xmlrpc的php扩展,那么请正确安装。在Windows平台下,首先把PHP安装目录下的扩展php_xmlrpc.dll放到C:Windows或者C:Winnt目录下,
(PHP4的扩展在C:phpextensions目录中,PHP5的扩展在C:phpext目录中),同时在
在apache 的安装目录下的php.ini中把extension=php_xmlrpc.dll前面的分号";"去掉,然后重
启Web服务器后查看phpinfo()有没有XML-RPC项目就能够确定是否已经正确安装xmlrpc扩展。

client.php

  1. <?php 
  2. /**
  3.  * 函数:提供给客户端进行连接XML-RPC服务器端的函数
  4.  * 参数:
  5.  * $host 需要连接的主机
  6.  * $port 连接主机的端口
  7.  * $request 封装的XML请求信息
  8.  * 返回:连接成功成功返回由服务器端返回的XML信息,失败返回false
  9.  */
  10. function do_call($host, $port, $request) { 
  11.     //打开指定的服务器端
  12.     $fp = fsockopen($host, $port, $errno, $errstr); 
  13.     //构造需要进行通信的XML-RPC服务器端的查询POST请求信息
  14.     $query = "POST /server.php HTTP/1.0\nUser_Agent: My Egg Client\nHost: ".$host."\nContent-Type: text/xml\nContent-Length: ".strlen($request)."\n\n".$request."\n"; 
  15.     //把构造好的HTTP协议发送给服务器,失败返回false
  16.     if (!fputs($fp, $query, strlen($query))) { 
  17.         $errstr = "Write error"; 
  18.         return 0; 
  19.     } 
  20.     //获取从服务器端返回的所有信息,包括HTTP头和XML信息
  21.     $contents = ''; 
  22.     while (!feof($fp)) { 
  23.         $contents .= fgets($fp); 
  24.     } 
  25.     //关闭连接资源后返回获取的内容
  26.     fclose($fp); 
  27.     return $contents; 
  28. } 
  29. //构造连接RPC服务器端的信息
  30. $host = '127.0.0.1'; 
  31. $port = 8080; 
  32. //把需要发送的XML请求进行编码成XML,需要调用的方法是cycle,参数是egg
  33. $request = xmlrpc_encode_request('cycle', 'egg'); 
  34. //调用do_call函数把所有请求发送给XML-RPC服务器端后获取信息
  35. $response = do_call($host, $port, $request); 
  36. //分析从服务器端返回的XML,去掉HTTP头信息,并且把XML转为PHP能识别的字符串
  37. $split = '';
  38. $xml = explode($split, $response);
  39. $xml = $split . array_pop($xml);
  40. $response = xmlrpc_decode($xml);
  41. //输出从RPC服务器端获取的信息
  42. print_r($response);
  43. ?>

server.php

  1. <?php 
  2. /**
  3.  * 函数:提供给RPC客户端调用的函数
  4.  * 参数:
  5.  * $method 客户端需要调用的函数
  6.  * $params 客户端需要调用的函数的参数数组
  7.  * 返回:返回指定调用结果
  8.  */
  9. function lifecycle($method, $params) { 
  10. /* $method = 'cycle', $params = (array of) request parameter(s); $data is also passed from xmlrpc_server_call_method, if we had any data to pass */ 
  11.     switch($params[0]) { 
  12.         case 'egg': 
  13.             $reply = 'All eggs will be birds one day.'; 
  14.         break; 
  15.         default: 
  16.             $reply = 'That must have been an otheregg'; 
  17.     } 
  18.     return $reply; 
  19. } 
  20. //产生一个XML-RPC的服务器端
  21. $server = xmlrpc_server_create(); 
  22. /* register the 'external' name and then the 'internal' name */ 
  23. xmlrpc_server_register_method($server, "cycle", "lifecycle"); 
  24. $request = $HTTP_RAW_POST_DATA; // no you don't need 'always on', and no $_POST doesn't work. 
  25. /* the parameters here are 'server, xml-string and user data'. There's supposed to be an optional 'output options' array too, but I can't get it working :( hence header() call */ 
  26. $response = xmlrpc_server_call_method($server, $request, null); 
  27. header('Content-Type: text/xml'); 
  28. print $response; 
  29. //销毁XML-RPC服务器端资源 
  30. xmlrpc_server_destroy($server); 
  31. ?>

运行输出:All eggs will be birds one day. 

你可能感兴趣的:(php xmlrpc的简单实用)