更新于 2013-11-22 01:15:40 UEANER

简介

通常我们的应用服务需要在不同的平台进行交互操作的时候,会使用 WEB服务.

常用的WEB服务有以下三种:

  • SOAP(简单对象访问协议): 支持多种协议(http/https/smtp等),W3C专门定义的一些标准
  • XML-RPC(远程过程调用): 只支持http协议,没有标准
  • REST(表征状态转移): 只支持http协议,是一种针对于资源理解的URI设计风格而没有标准, 加上 OAuth(开放授权)会让你的WEB服务(或开放平台)看上去更加简洁和简单,之后的文章会详细介绍。

本篇文章重点:SOAP 简单对象访问协议(Simple Object Access Protocol)。

PHP SOAP

模式

SOAP 分为 WSDL 和 non-WSDL 模式,可以简单理解为:WSDL 模式对外提供 WSDL 定义文件, 而 non-WSDL 模式不对外提供 WSDL 定义文件(会有人给你发一个接口文档的)。

依赖

php-soap 扩展,如果不存在此扩展,安装:

# yum install php-soap

或编译 PHP:--enable-soap

或使用:nusoap 包。

实例

本文使用 php-soap 扩展,做了一个例子,源码地址为:https://github.com/ueaner/soap,目录结构说明:

$ tar xf soap.tar.bz2

$ tree -C soap
soap
|-- class                   # 提供服务的类目录
    |-- Person.class.php    # 提供服务的类文件
|-- Client.php              # 客户端类
|-- non-wsdl                # non-WSDL 模式:提供服务的目录
    |-- PersonService.php   # non-WSDL 模式:提供服务的文件
|-- readme.txt              # readme
|-- Service.php             # 服务端类
|-- test.php                # 测试文件
|-- wsdl                    # WSDL 模式:提供服务的目录
    |-- PersonService.php   # WSDL 模式:提供服务的文件
|-- xml                     # WSDL 模式:生成的 WSDL xml 的目录
    |-- Person.wsdl         # WSDL 模式:生成的 WSDL xml 的文件

4 directories, 8 files

Client.phpService.php 均实现了 WSDL 和 non-WSDL 两种模式。

WSDL 模式 和 non-WSDL 模式对照表:

                WSDL 模式            non-WSDL 模式
SoapServer
    参数1     SomeService.php?wsdl       null
    参数2       uri 可有,可无             uri
SoapClient
    参数1     SomeService.php?wsdl       null
    参数2       uri 可有,可无         uri + location

这里的 SomeService.php?wsdl 类似 http://127.0.0.1:80/soap/wsdl/PersonService.php?wsdl 这样的地址(有 ?wsdl), location 是类似 http://127.0.0.1:80/soap/wsdl/PersonService.php 这样的地址(无 ?wsdl)。 uri 一般为你的根域名,如 http://localhost,或与 location 参数定义相同都可。

另外 WSDL 模式对外提供 WSDL 定义的 xml 文件,所以在以 GET 方式访问 http://127.0.0.1:80/soap/wsdl/PersonService.php?wsdl 地址时会输出相应的 xml 文件,对接口对象或函数进行说明。

具体实现请见 https://github.com/ueaner/soap 源码,如有疑问,欢迎在本页下方进行回复。

转载请注明出处。
本文地址:http://blog.aboutc.net/php/57/php-soap-example

评论:5

aimutran 2014-04-14 10:58:10
请问我用class类继承了一个类,然后
$server = new SoapServer(NULL,$options);$server>setClass(class);之后可以客户端调用父类和class类的所有方法,但是唯独父类或class类的构造方法怎么都不执行,请问这是什么原因!SOAP没有实例化?
ueaner 2014-04-28 00:09:24
@aimutran: 不好意思,看着有点晚,你可以尝试在子类的__construct构造方法中调用parent::__construct();方法。
aimutran 2014-04-28 00:26:08
嗯嗯,谢谢了, 测试发现父类的和子类构造方法是执行了,但是我在构造方法里 加了一个验证判断 目的就是如果没通过验证就退出[exit()] 测试的时候直接在构造方法里exit()但是发现程序还是执行了调用的那个方法 这个有办法解决么?
ueaner 2014-04-28 21:24:45
@aimutran: 应该是你的判断条件确实满足了吧。
James 2017-08-04 11:33:26
为什么我下载了直接运行  一直是   Error Message: Not Found
关闭高亮高亮 分享到新浪微博分享到新浪微博