php中xml-rpc构造webservice

php中集成了xml-rpc和soap两种协议的访问,都是集中在xmlrpc扩展当中。另外,在php的pear中,不管是php 4还是php 5,都已经默认集成了xml-rpc扩展,而且该扩展跟xmlrpc扩展无关,能够独立实现xml-rpc的协议交互,如果没有xmlrpc扩展,建议使用pear::xml-rpc扩展。

web service介绍

web service就是为了异构系统的通信而产生的,它基本的思想就是使用基于xml的http的远程调用提供一种标准的机制,而省去建立一种新协议的需求。目前进行web service通信有两种协议标准,一种是xml-rpc,另外一种是soap。xml-rpc比较简单,出现时间比较早,soap比较复杂,主要是一些需要稳定、健壮、安全并且复杂交互的时候使用。

我们这里主要是以xml-rpc来简单描述web service的交互过程,部分内容来自php手册,更详细内容,建议参考手册。

安装xmlrpc扩展

如果你的系统中没有安装xmlrpc的php扩展,那么请正确安装。

在windows平台下,首先把php安装目录下的扩展php_xmlrpc.dll放到c:windows或者c:winnt目录下,(php4的扩展在c:phpextensions目录中,php5的扩展在c:phpext目录中),同时在c:windowsphp.ini或者c: winntphp.ini中把extension=php_xmlrpc.dll前面的分号”;”去掉,然后重启web服务器后查看 phpinfo()有没有xml-rpc项目就能够确定是否已经正确安装xmlrpc扩展。

在unix/linux平台下,如果没有安装xmlrpc扩展,请在重新编译php,在configure的时候请加入 –with-xmlrpc 选项,然后查看phpinfo()看是否正常安装xmlrpc。

(注意:以下操作都是建立在xmlrpc扩张正常安装前提下,请务必正确安装。)

xml-rpc工作原理

xml-rpc大致就是整个过程就是使用xml来进行通信。首先构造一个rpc 服务器端用来出来从rpc客户端传递过来的使用xml封装的请求,并且把处理结果通过xml的形式返回给rpc客户端,客户端就去分析xml获取自己需要的数据。

xml-rpc的服务器端必须有现成的函数提供给客户端调用,并且客户端提交的请求中的函数和方法必须和服务器端的一致,否则将无法获取所需要的结果。

下面我进行简单的代码来描述整个过程。

xml-rpc实践

服务器端使用xmlrpc_server_create函数产生一个服务器端,然后把需要需要暴露的rpc调用接口进行注册,接受rpc客户端post过来的xml数据,然后进行处理,处理结果通过xml的形式显示给客户端。

代码如下: rpc_server.php

服务器端构造好了,那么再构造我们的rpc客户端。客户端大致通过socket访问xml-rpc服务器端的80端口,然后把需要调用的rpc接口封装到xml里,通过post请求提交给rpc服务器端,最后获取服务器端返回结果。

代码如下:rpc_client.php

大致我们上面的例子就是提交一个叫做rpc_server的方法过去,参数是get,然后获取服务器端的返回,服务器端返回的xml数据是:

this data by get method

那么我们再通过xmlrpc_decode函数把这个xml编码为php的字符串,我们就能够随意处理了,整个web service交互完成。

结束语

不管是xml-rpc也好,soap也罢,只要能够让我们稳定、安全的进行远程过程的调用,完成我们的项目,那么就算整个web service就是成功的。另外,如果可以的话,也可以尝试使用pear中的xml-rpc来实现上面类似的操作,说不定会更简单,更适合你使用。

简单的使用xml-rpc进行web service交互就完成了,部分代码参考php手册,想获取详细信息建议参考手册,如果文章有不正确,请指正。本篇文章来源于 php资讯 原文链接:html/84/n-33884.html”>http://www.phpchina.com/html/84/n-33884.html

http://www.bkjia.com/phpjc/508344.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/508344.htmltecharticlephp中集成了xml-rpc和soap两种协议的访问,都是集中在xmlrpc扩展当中。另外,在php的pear中,不管是php 4还是php 5,都已经默认集成了xml-rpc扩展…

Posted in 未分类