使用php来实现网络服务


Posted in PHP onSeptember 15, 2009

作者:samisa
以下文中的翻译名称对照表 :
payload: 交谈内容
object: 实例
function: 函数
使用 php来实现网络服务
使用框架: WSO2 WSF/PHP
安装环境: windows 或者 linux
(厌恶于眼下计算机文章夹杂无数难懂的翻译以及术语,此处尽量使用口语以及汉语。)
WSMessages 类:
在调用网络服务的过程中,需要两个消息,发送的消息和接受的消息,又来有往方能来往不是。 WSMessages 这个类就是在 Web services framework for php (简称 WSF)这个开源框架中,用来封装这两个消息的类。
WSMessages 有一个很重要的变量 str来保存消息内容,以 xml格式来保存“有效的载荷” (他们把这个叫做 payload,我查英文字典,就是这个意思,但是它来回的出现,反复的出现,今观之,也就是交谈内容,实际上就是除去那些 xml的定义,以及一些其他的所谓‘命名空间' ->namespace的定义而已。要搞清楚什么是命名空间,请查看 xml的 W3C定义 )。有效载荷实在是莫名其妙,我以后还是用‘交谈内容'来指代它把。
如果你通过客户程序发送一个请求,那么你需要构造一个 WSMessage 的实例,并且用 xml形式的交谈内容填写好这个实例。对应请求的回应,也还是一个‘交谈内容'会通过你的程序返回,并且返回的东西也仍然是一个 WSMessage 实例。
也就是说,你的客户端函数掉应一个网络服务,那么他的返回值也是一个 WSMessage 实例。
你可以在一个函数中发送请求,调用网络服务的程序,并且把返回内容放在 WSMessage实例中,并且让函数返回这个 WSMessage实例。
WSMessage 更倾向于发送和接受比较复杂的内容比如有附件什么的。下面就来详细解释一下如何使用 WSMessage 来实现客户端和服务端的交流。
处理交谈内容:
在此之前已经讲解过如何使用 php来创建网络服务,并且已经做了一个简单的客户 -服务端程序来说明工作流程。但是这些程序并没有深入的解释我们怎么处理‘交谈内容'。换句话来说,我们只是把 xml格式的交谈内容发送到了服务端,但并没有想到去处理它。在这里,我们来详细的解释一下如何处理交谈内容并且把它用到计算程序中去。
交谈内容是一个商业逻辑定义的内容,并且用 SOAP( Simple Object Access Protocol)来封装的,(请参见 SOAP w3c的文章)。让我们用个例子来说明如何计算一个阶乘吧。
客户端需要发送的交谈内容:
<getFactorial>
<param>6</param>
</getFactorial>
服务端需要明白这个交谈内容并且把变量分辨出来并且计算它的阶乘。下面就是服务端程序:
function getFactorial ( $message ) {
$simplexml = new SimpleXMLElement ( $message -> str ) ;
$value = $simplexml -> param [ 0 ] ;
$result = factorial ( $value ) ;
$responsePayloadString = <<<XML
<getFactorialResponse>
<result> $result </result>
</getFactorialResponse>
XML;
return $responsePayloadString ;
}
第 3行,我们用输入的‘交谈内容'创建了一个 simpleXmlElement 的实例。你可以看到,输入的交谈内容被保存到了通过函数参数传递进来的 WSMessage 实例 $message的 str变量中。注: SimpleXml是一个 php的扩展,用于处理 xml文件或者字符串。 WSO2 WSF/PHP并没有规定我们必须使用哪一个 php扩展来处理 xml。你可以使用你喜欢的人和 xml php 扩展来处理,比如 domdocument, saxdom之类。
第 4行将交谈内容中的参数值提取出来,这表示服务程序需要知道如何理解这些参数,比如说参数类型之类的东西。(正常来说需要在交谈内容中说明这个参数的类型)。函数中剩下的就是正常的处理阶乘。在第六行,阶乘通过调用其他函数被计算出来。从 8到 12行,回复的交谈内容也被写好并且准被返回此内容。第 14行我们返回回复的交谈内容。
回复的交谈内容应该差不多是这样的:
<getFactorialResponse>
<result>720</result>
</getFactorialResponse>
同样的,客户端也可以用同样的方法处理回复的交谈内容:
$response = $client -> request ( $reqestPayloadString ) ;
$simplexml = new SimpleXMLElement ( $response -> str ) ;
echo "Result = " . $simplexml -> result [ 0 ] . "<br/>" ;
在第 3行,用回复的交谈内容创建了一个 SimpleXMLElement 实例。同样的 $response 也是一个 WSMessage的实例,我们可以访问他的成员变量 str,这个变量保存了 xml格式的回复的交谈内容。我们把它交给一个 SimpleXMLElement 构造函数,由此创建一个 SimpleXMLElement的实例。然后我们就可以访问结果元素 (或者叫节点? element, xml里面可以称之为元素,但对于树状结构的它来说,节点也不为过? )
现在你应该学会如何处理交谈信息中的内容,不管是客户端的申请也好还是服务端的回应也好。
注:在服务端的 getFactorial函数 (14行 ),你可以之间返回一个 WSmessage而不是一个回复的交谈内容。你可以用下面的这一小段程序来实现这个功能。
$outMessage = new WSMessage( $responsePayloadString );
return $outMessage ;
这其实也就是说服务端程序及可以返回 xml格式的交谈内容也可以返回 WSMessage的实例
完整的程序将在这篇文章的末尾附上。
跟踪消息
通过 WSO2 Web services framework for PHP ,你可以跟踪 SOAP消息被客户端发出,然后客户端又收到了来自服务端的消息,(即他们的交谈内容)。网络客户服务类, WSClient 有两个函数可以实现这个目的: getLastReauest()和 getLastResponse()。客户端在使用 request()这个函数以后,你可以通过这两个函数去得到交谈信息。
$response = $client -> request ( $reqestPayloadString ) ;
printf ( "<br/> Request = %s </br>" ,
htmlspecialchars ( $client -> getLastRequest ())) ;
printf ( "<br/> Response = %s </br>" ,
htmlspecialchars ( $client -> getLastResponse ())) ;
以上的程序片段会显示 request()这个函数实现的请求与回复的内容。
实际上,这段程序差不多会输出这样的东西:
Request = <soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope"><soapenv:Header/><soapenv:Body><getFactorial> <param>6</param> </getFactorial></soapenv:Body></soapenv:Envelope>
Response = <soapenv:Envelope xmlns:soapenv="http://www.w3.org/2003/05/soap-envelope"><soapenv:Header/><soapenv:Body><getFactorialResponse> <result>720</result> </getFactorialResponse></soapenv:Body></soapenv:Envelope>
跟踪 SOAP消息对于研究呼叫的服务是非常有用的,特别是对于查找服务和客户端的 bug。比如说,你可以确认所有的客户端发出的消息以及服务端回复的消息,并且,你可以确认交谈内容的格式 (客户端的以及服务端的。 )
Debugging(这个词是如此的普遍,那么我在这里就不翻译它了,尽管我的梦想是有一天程序用中文来写,显而易见的是这个梦已经离我们越来越遥远。 )
用户在使用 php WSF有时会碰到两个问题:
安装 wsf。 你怎么能确定这个 wsf已经正常工作了?好吧,第一,你可以通过 phpinfo()这个函数来检查, (要是你不知道这个函数以及怎么使用它,呃,查查 php手册吧。 ) 你只需要创建一个 php文件,并且在上面写下这几句话,然后用个浏览器打开它。
<?php
phpinfo () ;
?>
如果所有的扩展都被正确的安装的话,你会找到一个项目叫 wsf,在一个以 wsf作为标题的表里,你应当看到 'wsf support'之类的字样。这个东东是在 php.ini里定义的,(或者比如说我就没有在 php.ini 里面定义而是在 /etc/php5/conf.d/里写了一个新的文件叫做 wsf.ini,实际上这个文件夹里面所有的文件到后来都会被合并到 php.ini里,所有如果你没有在 php.ini里找到相应的设置但是你的 wsf缺能用,你不妨来这里看看。 )
如果这个扩这没有显示在 phpinfo里,那么你需要去找安装指南来好好研究一下,如果找不到可以给我发 email: ferdinandfly@yahoo.ca
当你成功的安装了以后,第二个问题就是你好像并不能让这个例子正确运行。同样的,你需要检查一些设置是否正确。 首先是 php.ini记录中,经常会设置一些日志文件的路径,也许他不存在或者是说他设定的路径 php5无法读写。还有,你应到确认 php.ini是否包含了一些脚本文件,而这些脚本文件都是可读的。
如果以上的这些都是正确的但是 wsf就是不干活,你可以查看一下日志文件。日志文件会被写到 wsf.log_path这条记录所确定的路径中。这个东东在 php.ini里进行设定。如果他没有被设定,那么 log就在 /tmp里( linux)。需要知道的是,在 windows平台中,默认的路径很可能不存在,因此你必须为他指定一个日志路径。和服务有关的日志记录在 wsf_php_server.log中,和客户端有关的保存在 wsf_php_client.log中,如果你的客户机和服务主机不是一台机器,那么这两个文件都在服务器上哦。你可以通过调节记录的等级来获得不同详细程度的日志文件。如果是调试,你可以把它设置为 level 4,当然如果是成熟的软件,你可以设置为 0(仅仅是严重错误)或者是 1(错误)。
如果你想确认来往的交谈内容( SOAP)是你所想要的格式的话,你可以用 SOAP 消息跟踪来调试,正如我们前面所讲的。
总结:
在这篇文章中,我解释了 WSMessage这个类以及怎样处理交谈内容并且使用它,客户端或者服务端都可以通过调用 str这个 WSMessage的成员变量来获得交谈内容( xml)。通常交谈内容的格式都是通过 WSDL来定义的,因此我们要求客户端和服务端需要遵守同样的格式是合理的。下一章我们会讨论如何通过 WSO2 WSF/PHP和 WSDL协同工作 .

PHP 相关文章推荐
PHP 采集获取指定网址的内容
Jan 05 PHP
php实现utf-8和GB2312编码相互转换函数代码
Feb 07 PHP
基于php实现长连接的方法与注意事项的问题
May 10 PHP
php 检查电子邮件函数(自写)
Jan 16 PHP
将CMYK颜色值和RGB颜色相互转换的PHP代码
Jul 28 PHP
基于PHP的简单采集数据入库程序
Jul 30 PHP
从零开始学YII2框架(二)通过 Composer 安装扩展插件
Aug 20 PHP
php实现微信公众平台账号自定义菜单类
Dec 02 PHP
PHP使用Mysqli类库实现完美分页效果的方法
Apr 07 PHP
分析PHP中单双引号的误区和双引号小隐患
Jul 19 PHP
php二维数组按某个键值排序的实例讲解
Feb 15 PHP
PHP7新功能总结
Apr 14 PHP
Discuz 6.0+ 批量注册用户名
Sep 13 #PHP
火车头discuz6.1 完美采集的php接口文件
Sep 13 #PHP
PHP 分页类(模仿google)-面试题目解答
Sep 13 #PHP
frename PHP 灵活文件命名函数 frename
Sep 09 #PHP
PHPLog php 程序调试追踪工具
Sep 09 #PHP
php 从数据库提取二进制图片的处理代码
Sep 09 #PHP
封装一个PDO数据库操作类代码
Sep 09 #PHP
You might like
PHP 单引号与双引号的区别
2009/11/24 PHP
Could not load type System.ServiceModel.Activation.HttpModule解决办法
2012/12/29 PHP
preg_match_all使用心得分享
2014/01/31 PHP
基于php判断客户端类型
2016/10/14 PHP
通过源码解析Laravel的依赖注入
2018/01/22 PHP
详解php与ethereum客户端交互
2018/04/28 PHP
PHP PDO和消息队列的个人理解与应用实例分析
2019/11/25 PHP
jquery tab插件制作实现代码
2010/06/22 Javascript
JQuery扩展插件Validate—6 radio、checkbox、select的验证
2011/09/05 Javascript
使用jQuery清空file文件域的解决方案
2013/04/12 Javascript
javascript实现焦点滚动图效果 具体方法
2013/06/24 Javascript
解析Javascript中大括号“{}”的多义性
2013/12/02 Javascript
Jquery对数组的操作技巧整理
2014/03/25 Javascript
【经典源码收藏】基于jQuery的项目常见函数封装集合
2016/06/07 Javascript
详解JavaScript中数组的reduce方法
2016/12/02 Javascript
详解vue中computed 和 watch的异同
2017/06/30 Javascript
VueRouter导航守卫用法详解
2017/12/25 Javascript
微信小程序block的使用教程
2018/04/01 Javascript
jQuery中ajax请求后台返回json数据并渲染HTML的方法
2018/08/08 jQuery
BootStrap中的模态框(modal,弹出层)功能示例代码
2018/11/02 Javascript
详解如何使用nvm管理Node.js多版本
2019/05/06 Javascript
对python的输出和输出格式详解
2018/12/08 Python
python使用wxpy实现微信消息防撤回脚本
2019/04/29 Python
python中update的基本使用方法详解
2019/07/17 Python
在flask中使用python-dotenv+flask-cli自定义命令(推荐)
2020/01/05 Python
python 操作mysql数据中fetchone()和fetchall()方式
2020/05/15 Python
浅析Python面向对象编程
2020/07/10 Python
Java中的异常处理机制的简单原理和应用
2013/04/27 面试题
理财投资建议书
2014/03/12 职场文书
高一学生期末评语
2014/04/25 职场文书
服装区域经理岗位职责
2015/04/10 职场文书
创业方案:赚钱的烧烤店该怎样做?
2019/07/05 职场文书
React中的Context应用场景分析
2021/06/11 Javascript
mysql中整数数据类型tinyint详解
2021/12/06 MySQL
Go 中的空白标识符下划线
2022/03/25 Golang
DE1103使用报告
2022/04/05 无线电