php4时代调用webservice大部分使用的nusoap。到了php5已经有了自己的soap扩展。所以可以完全的抛弃nusoap这个许久没有更新过的东西了。
因为目前是本地开发需要。只说windows下的。
配置环境
windows下找到php安装目录下的php.ini。打开后编辑。找到
extension=php_soap.dll
然后将前面的;号去掉。
然后就是写一个php文件来验证一下。
实例程序
在apache的htdocs目录下创建ws.php
代码如下:
<?php header("content-type:text/html;charset=utf-8"); try { $client = new SoapClient( 'http://erp.test.com/SendSMS/Service.asmx?wsdl',array('trace' => true, 'exceptions' => true )); var_dump($client->__getFunctions()); } catch (SOAPFault $e) { print_r($e); } ?>
在浏览器中输入:http://localhost/ws.php后会出现
array 0 => string 'SendSMSResponse SendSMS(SendSMS $parameters)' (length=44) 1 => string 'SendSMS1Response SendSMS1(SendSMS1 $parameters)' (length=47) 2 => string 'SendMailResponse SendMail(SendMail $parameters)' (length=47) 3 => string 'IsSendSMSResponse IsSendSMS(IsSendSMS $parameters)' (length=50) 4 => string 'IsSendSMS1Response IsSendSMS1(IsSendSMS1 $parameters)' (length=53) 5 => string 'SendSMSResponse SendSMS(SendSMS $parameters)' (length=44) 6 => string 'SendSMS1Response SendSMS1(SendSMS1 $parameters)' (length=47) 7 => string 'SendMailResponse SendMail(SendMail $parameters)' (length=47) 8 => string 'IsSendSMSResponse IsSendSMS(IsSendSMS $parameters)' (length=50) 9 => string 'IsSendSMS1Response IsSendSMS1(IsSendSMS1 $parameters)' (length=53)
现在逐行解释一下。
$client = new SoapClient(
'http://erp.test.com/SendSMS/Service.asmx?wsdl',array('trace' =>
true, 'exceptions' => true ));
这里的SoapClient类可以作为给定的ws的客户端。这个SoapClient有两种操作模式。
一个是WSDL模式,一个是Non-WSDL模式。
当然这里用的是WSDL模式。所以重点来说第一种。
WSDL模式中,SoapClient的构造参数分别是ws的请求地址以及各种请求配置参数。
var_dump($client->__getFunctions());
这里就是访问后输出的这个接口可提供的方法,返回值以及参数。
那么如何去调用方法呢。
<?php header("content-type:text/html;charset=utf-8"); try { $client = new SoapClient( 'http://erp.test.com/SendSMS/Service.asmx?wsdl', array('trace' => true, 'exceptions' => true )); var_dump($client->__getFunctions()); //第一个参数是命名空间,第二个参数是SoapHeader头的类名,第三个是SoapHeader参数的数组可以写成array $v = array("Token"=>""); $headers = new SoapHeader("http://test.com/","AuthenticationHeader",$v, false, SOAP_ACTOR_NEXT); $client->__setSoapHeaders(array($headers)); //$types = $client->__getTypes(); //这里是为了查看方法的类型 //print_r($types); //这里就是根据方法参数的需要虚拟出来一个sms类型的数组 $sms1 = array( 'Id'=>100000, 'SjNo'=>'13512222222', 'UnickName'=>'tuangou', 'SmsContent'=>'test', 'Type'=>1000, 'OrderIdString'=>'1231114567' ); $param = array( 'sms1'=>$sms1 ); //这里是需要注意到地方。调用方法的参数必须是一个数组。而且默认以parameters字段标识为参数数组。真正的参数都要放在$param变量中。 $return = $client->__soapCall("SendSMS1",array('parameters'=>$param)); print_r($return); } catch (SOAPFault $e) { print_r('Exception:'.$e); } ?>
POST /SendSMS/Service.asmx HTTP/1.1 Host: erp.test.com Content-Type: text/xml; charset=utf-8 Content-Length: length SOAPAction: "http://test.com/SendSMS1" <?xml version="1.0" encoding="utf-8"?> <soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"> <soap:Header> <AuthenticationHeader xmlns="http://test.com/"> <Token>string</Token> </AuthenticationHeader> </soap:Header> <soap:Body> <SendSMS1 xmlns="http://test.com/"> <sms1> <Id>int</Id> <SjNo>string</SjNo> <UnickName>string</UnickName> <SmsContent>string</SmsContent> <Type>int</Type> <OrderIdString>string</OrderIdString> </sms1> </SendSMS1> </soap:Body> </soap:Envelope>
这里可以看到。soap的Header和Body。Header里就是Token。Body里就是具体的方法了。
SendSMS1节点是方法名。
sms1节点就是参数。
sms1节点下的就是参数的属性。
一定要按照顺序对属性进行逐个赋值。
http://www.360doc.com/content/11/0212/16/15103_92457365.shtml