您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

webservice——nusoap详解

2024/5/14 19:30:59发布44次查看
php soap服务器
用php和nusoap来建立soap服务器非常容易。基本上,你只要写出你想要暴露给你的web services的函数,然后用nusoap去注册它们就可以了。ok,另外还需要两步才能完成php soap服务器的建立。首先你还要在你的php代码中创建nusoap对象的一个实例,然后用http post方法将原始数据传给nusoap进行处理
nusoap的使用比较简单,其中最常用到的类是soap_server和soapclient,其中soap_server用于创建 webservice服务,类soapclient则用于调用webservice.这两个类的定义都在lib/nusoap.php中,因此我们在创建 或调用webservice接口程序时均需要引用该文件.  
nusoap是php环境下的webservice编程工具,用于创建或调用webservice。它是一个开源软件,是完全采用php语言编写的、通过http收发soap消息的一系列php类,由nusphere corporation(http://dietrich.ganx4.com/nusoap/  )开发。nusoap的一个优势是不需要扩展库的支持,这种特性使得nusoap可以用于所有的php环境,不受服务器安全设置的影响。
1.首先,去http://sourceforge.net/projects/nusoap/下载nusoap.zip。
2.服务端:建立nusoapservice.php文件。
[php]view plaincopy
soap_defencoding = 'utf-8';  $server->decode_utf8 = false;  $server->xml_encoding = 'utf-8';  $server->configurewsdl ('test'); // 打开 wsdl 支持  /* 注册需要被客户端访问的程序 类型对应值: bool->xsd:boolean    string->xsd:string int->xsd:int     float->xsd:float */  $server->register ( 'getteststr', // 方法名  array (name => xsd:string ), // 参数,默认为 xsd:string  array (return => xsd:string ) ); // 返回值,默认为 xsd:string  //isset  检测变量是否设置  $http_raw_post_data = isset ( $http_raw_post_data ) ? $http_raw_post_data : '';  //service  处理客户端输入的数据  $server->service ( $http_raw_post_data );  /**  * 供调用的方法  * @param $name  */  function getteststr($name) {      return hello,  { $name } !;  }  ?>
3.客户端:建立nusoapclient.php文件。
[php]view plaincopy
soap_defencoding = 'utf-8';  $client->decode_utf8 = false;  $client->xml_encoding = 'utf-8';  // 参数转为数组形式传递  $paras = array ('name' => 'bruce lee' );  // 目标方法没有参数时,可省略后面的参数  $result = $client->call ( 'getteststr', $paras );  // 检查错误,获取返回值  if (! $err = $client->geterror ()) {      echo  返回结果: , $result;  } else {      echo  调用出错: , $err;  }  ?>
[php]view plaincopy
soap_defencoding = 'utf-8';  $client->decode_utf8 = false;  $client->xml_encoding = 'utf-8';  // 参数转为数组形式传递  $paras = array ('name' => 'bruce lee' );  // 目标方法没有参数时,可省略后面的参数  $client->call ( 'getteststr', $paras );  $document = $client->document;  echo $document;   ?>  
注:返回结果: hello, { bruce lee } !wsdl
wsdl是一种用于描述web service的xml语言。它是一种机读格式,把所有的访问服务所必须的信息提供给web service客户端。nusoap专门提供一个类进行wdsl文件的解析,并且从中提取信息。soapclient对象使用wsdl类来减轻开发者调用服务的难度。通过wsdl信息的帮助来创建报文,程序员仅仅需要知道操作的名字和参数就能调用它。
通过nusoap使用wsdl提供以下几点优点:
所有的服务元文件,如命名空间(namespaces),endpoint urls,参数名(parameter names)等等都可以直接从wsdl文件获得,这样就允许客户端动态的适应服务器端的变化。因为从服务器随时可以获得,所以这些数据不再需要在用户脚本中使用硬性编码。
它允许我们使用soap_proxy类。这个类派生自soapclient类,增加了wdsl文件中详细列出的操作所对应的方法。现在用户通过它可以直接调用这些方法。
soapclient 类包含一个getproxy()方 法,它返回一个soap_proxy类的一个对象。soap_proxy类派生自soapclient类,增加了对应于 wsdl文档中定义的操作的方法, 并且允许用户调用一个endpoint的远程方法。这仅仅适用于soapclient对象用wdsl文件初始化的情况。优点是易于用户使用,缺点是性能--php中创建对象是耗时的--且不为功利目的服务 (and this functionality serves no utilitarian purpose)。
[php]view plaincopy
soap_defencoding = 'utf-8';  $client->decode_utf8 = false;  $client->xml_encoding = 'utf-8';  //生成proxy类    $proxy = $client->getproxy();    //调用远程函数    $sq = $proxy->getteststr('bruce lee');   if (!$err=$proxy->geterror()) {    print_r($sq);    } else {    print error: $err;    }        print 'request:<xmp>'.$p->request.'</xmp>';    print 'response:<xmp>'.str_replace('>, >\n, $p->response).'</xmp>';    ?>    
第四步:运行server端文件页面:http://localhost/nusoapservice.php生成的wsdl文件
点击方法名称。这样我们通过在service中增加了几行代码我们就通过使用nusoap为service提供了一个可视化的文档。但是,这还不是所有我们能做的。
我们在service中通过使用nusoap增加一些wsdl的调用我们可以为service生成wsdl还有一些其他的文档。与此不同的是,在 client中我们能做的就有些少了,至少在我们的这个简单的例子中是这样。下面所示的这个client跟没有使用wsdl的client没有什么不同 的,唯一的不同就是解析soapclent class是通过提供wsdl的url来完成的,而不是之前的通过service endpoint。
nusoap调用webservice出现乱码的解决方法:
[php]view plaincopy
$client->soap_defencoding = 'utf-8';    $client->decode_utf8 = false;    $client->xml_encoding = 'utf-8';    文件代码不能有任何输出,否则调用时会报类似如下错误: 
xml error parsing soap payload on line x(行号): reserved xml name
用nusoap实现webservice,不要开启php的soap扩展,原因是nusoap的soapclient类和php5内置的soap类有冲突。
解决方案
1. 修改php.ini不加载php5内置的soap扩展(windows下是php_soap.dll)。
2. 也有给nusoap的soapclient类改名的。
身份认证
[php]view plaincopy
 array(      'content-type' => 'text/xml; charset=utf-8',      'soapaction' => 'yourfunstion',  )  );  $client = new nusoap_client('http://www.yourdomain.com/service.asmx?wsdl', true, '', '', '', '');  $client->setheaders('    http://tempuri.org/webservice>    username     password        ');  $err = $client->geterror();  if ($err) {      echo 'constructor error'





. $err . '';  }  $result = $client->call('yourfunction', $params, '', '', false, true);  if ($client->fault) {      echo 'fault'





;      print_r($result);      echo '';  } else {      $err = $client->geterror();      if ($err) {          echo 'error'





. $err . '';      } else {          echo 'result'





;  //print_r($result);          echo '';      }  }  echo 'request'





. htmlspecialchars($client->request, ent_quotes) . '';  echo 'response'





. htmlspecialchars($client->response, ent_quotes) . '';  ?> 
以上就介绍了webservice——nusoap详解,包括了方面的内容,希望对php教程有兴趣的朋友有所帮助。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product