PHP写webservice服务端

1) WebService技术介绍

WebService是一种跨编程语言和跨操作系统平台的远程调用技术。只有通过Web Service,客户端和服务器才能够自由的用HTTP进行通信,不论两个程序的平台和变成语言是什么。

XMLSOAPWSDLWeb Service平台的三大技术:

WebService采用HTTP协议传输数据,采用XML格式封装数据,即XML中说明调用远程服务对象的哪个方法、传递的参数是什么、以及服务对象的返回结果是什么。XMLWebService平台中表示数据的格式,除了易于建立和易于分析外,XML主要的有点在于它既是平台无关的,又是厂商无关的。

SOAPWebService通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议,SOAP提供了标准的RPC方法来调用Web ServiceSOAP协议 = HTTP协议 + XML数据格式。

WSDLWeb Service Description Language)是基于XML的语言,用于描述Web Service及其函数、参数和返回值,它是WebService客户端和服务器端都能理解的标准格式。因为是基于XML的,所以WSDL及时机器可阅读的,又是人可阅读的。WSDL文件保存在Web服务器上,通过一个url地址就可以访问到它。客户端要调用一个WebService服务之前,要知道该服务的WSDL文件的地址。WebService服务提供商可以通过两种方式来暴露它的WSDL文件地址:1、注册到UUID服务器,以便被人查找;2、直接告诉给客户端调用者。

2) Apache相关配置

为了能够实现Web Servicehttpd必须支持soap的扩展,这里以yum安装httpdsoap扩展为例进行说明:

1> 安装httpd

   yum install httpd

2> 安装php

   yum install php

3> 配置httpd支持php解析

   在/etc/httpd/conf/httpd.conf中添加如下:

   AddType application/x-httpd-php .php

   AddType application/x-httpd-php-source .phps

4> 重新启动httpd

   service httpd restart

5> 检查是否安装了soap扩展

   /usr/bin/php -m | grep soap  //! 如果存在则说明已经安装了soap扩展,如果不存在,执行下一步

6> 安装soap扩展

   yum install php-soap //! 安装完之后再次检查,重启httpd

7> 验证soap扩展是否正确安装

   既可以通过php -m | grep soap的方式,也可以通过phpinfo();的方式。

3) PHP实现WebService服务端

1> 定义服务类——Service.php

该服务端就是实现你想要对外提供的接口,假设我们需要对外提供一个函数,它接收一个字符串,然后返回”Hello ” + 输入的字符串这个小功能,服务类很简单,如下所示:

<?php
   class Service
   {
		public function sayHello($content)
		{
		      return "Hello ".$content;
		}
   }
?>

2> 生成wsdl文件——create_wsdl.php

    为了生成wsdl文件,我们可以使用网上提供的SoapDiscovery.class.php中的getWSDL提供的方法来实现,该SoapDiscovery.class.php的代码在网上可以下载到,为了生成文件,我们需要修改getWSDL方法中的部分代码(加上写文件的代码),如下所示:

//return sprintf('%s%s%s%s%s%s', $headerWSDL, $portTypeWSDL, $bindingWSDL, $serviceWSDL, $messageWSDL, '</definitions>');
			
			//!注释掉return,添加如下代码,目的是为了调用getWSDL生成.wsdl文件
			$fso = fopen($this->class_name.".wsdl", "w");
			fwrite($fso, sprintf('%s%s%s%s%s%s', $headerWSDL, $portTypeWSDL, $bindingWSDL, $serviceWSDL, $messageWSDL, '</definitions>'));
                        fclose($fso);

现在我们就可以定义自己的create_wsdl.php了,只需要调用一下这个方法即可,如下:

<?php 
	include("Service.php");
	include("SoapDiscovery.class.php");	
	//! 第一个参数是类名,生成的wsdl文件就是以它来命名的;第二个参数是服务的名称,可以随便写
	$disco = new SoapDiscovery('Service', 'soap');
	$disco->getWSDL();
?>

3> 修改服务端——Service.php

修改Service.php,添加一些代码,如下所示:

<?php
   class Service
   {
		public function sayHello($content)
		{
		      return "Hello ".$content;
		}
   }
  
   $service = new SoapServer('http://192.168.17.129/soap/Service.wsdl', array('soap_version' => SOAP_1_2));
   $service->setClass("Service"); //! 注册Service类的所有方法
   $service->handle(); //! 处理请求
?>

4> 修改Service.wsdl文件

  

5> 客户端测试——client.php

client.php用来测试我们刚写的Web Server的服务端能否可用,代码如下:

<?php
   $soap = new SoapClient('http://192.168.17.129/soap/Service.php?wsdl');  
   echo $soap->sayHello("houqd2012");
?>

输出结果如下:

Hello houqd2012

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。