Web Service技术:
简称WS:WEB服务,是跨平台并提供各项服务的一种技术。WS就是一个程序,它有一个能够通过WEB进行调用的接口。通过调用这个接口,用户可以实现某个功能的实现。
特点:实现“基于WEB的无缝集成”,
组成WS平台的3个技术:
   SOAP(Simple Object Access Protocal)简单对象访问协议。
   WSDL(Services Description Language)WEB服务描述语言;
   UDDI(Universal Discovery Description Integration)通用发现,描述,集成。
SOAP协议:
SOAP是一种轻量级的协议,利用XML技术让应用程序跨HTTP进行信息交换。可以和许多因特网协议结合使用。包括:HTTP,SMIP,MIME等等.
特点:SOAP的可扩展性
   SOAP可以在几乎所有的传输协议上使用
   SOAP独立于平台,独立于语言,允许任何编程模型,并且不依赖于RPC(?)。
   SOAP是基于XML技术的,所以它遵循XML标准。一个SOAP包就是一个XML文档。
SOAP结构:
   <?xml version = "1.0" encoding = "gb2312"?>
   <!--Envelope 意思是:信封,封套。就是SOAP的最外层,即根元素。是SOAP必不可少的元素,结构如下:-->
   <soap:Envelope
   xmlns:soap="http://www.w3.org/2001/12/soap-envelope"
   soap:encodingStyle="http://www.w3.org/2001/12/soap-envelope">
   <!-- 其中元素Envelope的命名空间的只必须是"http://www.w3.org/2001/12/soap-envelope"。否则此SOAP无效
   在SOAP Envelope中还有个属性:encodingStyle.该属性定义了文档中的数据类型。该属性可以在SOAP的任何一个元素中
   -->
   <!--
   Header元素包含了Envelope的一些专用信息,该元素是可选的。如果使用则必须是Envelope的第一个子元素。
   结构如下:
   -->
    <soap:Header>
     <tm:Info xmlns:tm="http://www.bocd.com/php"
     soao:mustUnderstand="1">Tsoft</tm:Info>
    </值等于0表示可选。soap:Header>
   <!--
   上面的代码中,mustUnderstand是Header中的一个属性,用于标识标题项对于要进行处理的接收者来说是否必须处  

理。值等于1表示必须处理;
   -->
   <!--
   SOAP Body是Envelope根元素中的必要元素。用于错误处理的Fault元素就属于Body的子元素。它包含了SOAP的消息内容。
Fault元素用于保存SOAP中的错误信息及状态信息;如有则它必须是Body的子元素。并且最多只出现一次。Fault元素定义了以下4个子

元素:
<faultcode>:faultcode元素提供了故障代码
<faultstring>:该元素提供了错误的解释信息。类似与HTTP中的”Reason-Phrase“.
<faultactor>:该元素提供了导致错误发生的信息源
<detail>:该元素用来保存与Body元素有关的应用程序的错误信息。
如果Body元素的内容不能被成功的解析,则必须包含detail子元素。detail有一条编码规则:一个detail由它的元素全名(包括命名空间)确定。
faultcode元素提供的故障代码主要有4种:
   VersionMismatch:处理方发现SOAP封装元素又不合法的命名空间。
   MustUnderstand:不能处理header子元素,因为属性mustUnderstand = 1不被理解。
   Client:表示信息的格式错误或包含不正确的信息。
   Server: 表示错误原因来自服务器。 
-->
   <soap:Body xmlns:tm="http://bccd.com/PHP">
    <tm:PHP_book>
     <tm:Name>PHP</tm:Name> 
    </tm:PHP_book>
   <soap:Body>
</soap:Envelope>
这个XML文档主要由3部分组成。SOAP Envelope,SOAP Header和SOAP Body.此外,有一个Body的子元素:Fault。

WSDL文档:
WSDL是用XML语言来描述WEB Service.通过WDSL,可以了解WEB Service提供了那些方法,使用的协议和服务器地址等。WSDL文档主要由5部分元素组成。
结构:
<?xml version="1.0" encoding="gb2312"?>
<definitions xmlns="http://schemas.xmlsoap.org/wsdl/" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"

xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" xmlns:xs="http://www.w3.org/2001/XMLSchema"

xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/"

xmlns:tm="http://localhost/wwwbccdnet" targetNamespace="http://localhost/wwwbccdnet">
<!--types定义WEB Service所用到的数据类型-->
<types>
   <xs:schema/>
</types>
<!--message包含了web service的所有信息 包括发送的和接受的 传入值用request 输出值用response-->
<message name="getBccdRequest">
   <part name="user" type="xs:string"/>
</message>
<message name="getBccdResponse">
   <part name="return" type="xs:string"/>
</message>
<!--定义了web service可使用的方法及相关的信息-->
<portType name="getBccdPortType">
   <operation name="getBccd">
    <input message="tm:getBccdRequest"/>
    <output message="tm:getBccdResponse"/>
   </operation>
</portType>
<!--绑定portType描述service的接口和相关协议-->
<binding name="getBccdBinding" type="tm:getBccdPortType">
   <soap:binding style="rpc" transport="http://schemas.xmlsoap.org/soap/http"/>
   <operation name="getBccd">
    <soap:operation soapAction="http://localhost/wwwbccdnet/getBccd"/>
    <input>
     <soap:body use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/>
    </input>
    <output>
     <soap:body use="encoded" encodingStyle="http://schemas.xmlsoap.org/soap/encoding/"/>
    </output>
   </operation>
</binding>
<!--用来确定portType的地址-->
<service name="getBccdService">
   <port name="getBccdPort" binding="tm:getBccdBinding">
    <soap:address location="http://localhost/tm/sl/25/1/server.php"/>
   </port>
</service>
</definitions>

PHP内置SOAP类库:
使用SOAP类库的步骤:首先对SOAP进行一些配置。使PHP支持SOAP函数;然后建立一个WSDL文档;文档创建成功后,最后使用SOAP类创建服务器和客户端程序。
配置SOAP :
   在PHP中正确使用SOAP类库,需对php.ini文件做如下改动
   1):去掉“;extension=php_soap.dll”前的“;”
   2):找到SOAP的配置部分,修改后的信息如下所示:
   [soap]
   ;Enables or disables WSDL caching feature,
   soap.wsdl_cache_enabled=0
   ;Sets the directory name where SOAP extension will put cache files.
   soap.wsdl_cache_dir="e:\windows\temp"
   ... 
其中,soap.wsdl_cache_enabled设为0,意思为关闭WSDL缓存;soap.wsdl_cache_dir为缓存目录。除此之外,再将参数

always_populate_raw_post_data设为On,并去掉前面的分号,意思是允许威格士的post数据。重启服务器,如果配置正确,在phpinfo()里将能看到soap信息。
建立WSDL:
   创建服务器端页面,创建流程:
    实现函数功能-->实例化对象-->添加接口函数-->调用对象句柄。
   例如:<?php
    //实现函数功能
    function getBccd($user){
     if(preg_match('/^[a-zA-Z_]\w*/',$user) == 0){
      return 'register fail.&nbsp;<a href=\'index.php\'>back</a>';
     }else{
      return 'Succeed!Welcome: '.$user;
     }
    }
    $server = new SoapServer('tmbccd.wsdl');//实例化对象
    $server->addFunction("getBccd");//添加接口。
    $server->handle();//调用对象句柄。
   ?>
   客户端实际上就是通过服务器的接口函数来实现传值的功能。页面创建步骤:
    实例化对象-->调用接口函数-->输出结果 
   例如:<?php
    $user = $_POST['user'];
    $client = new SoapClient("http://localhost/tm/sl/25/3/tmbccd.wsdl");//实例化对象
    $return = $client->getBccd($user);//调用接口函数
    echo $return;//输出结果
    ?>
  http://localhost/tm/sl/25/3/tmbccd.wsdl:为services的地址

使用NUSOAP类包:
NuSOAP是一个源代码开放的SOAP类库,第三方扩展包;下载解压后会有两个文件夹,将其中lib文件夹拷贝到服务器相应的目录下就可以使用了。另一个sample文件夹是一些实例程序。
使用NuSOAP前先要在PHP.INI中将extension = php_soap.dll注释掉(前面加上分号),因为NuSOAP类库的类名有冲突。重启服务器即可使用。
NuSOAP类包主要包括三个类:soap_server,soapclient和soap_fault。
创建服务器端页面:
   载入NuSOAP类-->实例化对象-->配置WSDL文档-->注册接口函数-->函数功能实现。还可以使用对象中的service方法来查看

WSDL文档的内容和接口信息。
例如:<?php
   include ('../lib/nusoap.php');//载入NuSOAP类
   $server = new soap_server();//实例化对象
   $server->configureWSDL('myBccd');//配置WSDL文档
   $server->register('getBccd',array('user'=>'xsd:string'),array('return'=>'xsd:string'));//注册接口函数
   //函数功能实现
   function getBccd($user){
    return 'Succeed! '.$user. ', service is good.';
   }
   $server->service($HTTP_RAW_POST_DATA);
?>

创建客户端页面
   加载NuSOAP类-->实例化对象-->调用接口函数-->输出返回信息。
例如: <?php
   include '../lib/nusoap.php';//加载类库
   $client = new soapclient('http://localhost/tm/sl/25/2/server.php?wsdl',true);//实例化对象
   $return = $client->call('getBccd',array('user'=>'spcn'));//调用接口函数
   echo $return;//输出返回信息
?>