Maison >développement back-end >tutoriel php >PHP soap Web Service 使用SoapDiscovery.class.php 生成wsdl文件,_PHP教程

PHP soap Web Service 使用SoapDiscovery.class.php 生成wsdl文件,_PHP教程

WBOY
WBOYoriginal
2016-07-12 08:54:331332parcourir

PHP soap Web Service 使用SoapDiscovery.class.php 生成wsdl文件,

PHP soap web service 使用wsdl文件 demo:

==============================================================

服务端:

在使用wsdl的soap webservice demo 前先使用cw.php 文件生成wsdl文件, 代码如下:

cw.php:

<?<span>php

</span><span>include</span>("service.php"<span>);
</span><span>include</span>("SoapDiscovery.class.php"<span>);

</span><span>$disco</span> = <span>new</span> SoapDiscovery('soapHandle', 'myService'); <span>//</span><span>第一个参数是类名(生成的wsdl文件就是以它来命名的),即Service类,第二个参数是服务的名字(这个可以随便写)。</span>
<span>$disco</span>->getWSDL();<br /><br />?>

 

service.php:

<?<span>php

</span><span>include_once</span>("soapHandle.class.php"<span>);

</span><span>$server</span> = <span>new</span> SoapServer('soapHandle.wsdl', <span>array</span>('soap_version' => SOAP_1_2)); <span>#</span><span>#此处的Service.wsdl文件是上面生成的</span>
<span>$server</span>->setClass("soapHandle"); <span>//</span><span>注册Service类的所有方法 </span>
<span>$server</span>->handle(); <span>//</span><span>处理请求</span>

?>

 

soapHandle.class.php :

<?<span>php

</span><span>class</span><span> soapHandle{

    </span><span>public</span> <span>function</span> strtolink(<span>$url</span>=''<span>){
        </span><span>return</span> <span>sprintf</span>('<a href="%s">%s</a>', <span>$url</span>, <span>$url</span><span>);
    }
    
    </span><span>public</span> <span>function</span> add(<span>$a</span>=1, <span>$b</span>=2<span>)
    {
        </span><span>return</span> <span>$a</span>+<span>$b</span><span>;
    }

}

</span>?>

 

SoapDiscovery.class.php 代码如下:

===========================================================

PHP soap Web Service 使用SoapDiscovery.class.php 生成wsdl文件,_PHP教程php /** * Copyright (c) 2005, Braulio Jos?Solano Rojas * All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, are * permitted provided that the following conditions are met: * * Redistributions of source code must retain the above copyright notice, this list of * conditions and the following disclaimer. * Redistributions in binary form must reproduce the above copyright notice, this list of * conditions and the following disclaimer in the documentation and/or other materials * provided with the distribution. * Neither the name of the Solsoft de Costa Rica S.A. nor the names of its contributors may * be used to endorse or promote products derived from this software without specific * prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND * CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * * @version $Id$ * @copyright 2005 */ /** * SoapDiscovery Class that provides Web Service Definition Language (WSDL). * * @package SoapDiscovery * @author Braulio Jos?Solano Rojas * @copyright Copyright (c) 2005 Braulio Jos?Solano Rojas * @version $Id$ * @access public **/ class SoapDiscovery { private $class_name = ''; private $service_name = ''; /** * SoapDiscovery::__construct() SoapDiscovery class Constructor. * * @param string $class_name * @param string $service_name **/ public function __construct($class_name = '', $service_name = '') { $this->class_name = $class_name; $this->service_name = $service_name; } /** * SoapDiscovery::getWSDL() Returns the WSDL of a class if the class is instantiable. * * @return string **/ public function getWSDL() { if (empty($this->service_name)) { throw new Exception('No service name.'); } $headerWSDL = "\n"; $headerWSDL.= "$this->service_name\" targetNamespace=\"urn:$this->service_name\" xmlns:wsdl=\"http://schemas.xmlsoap.org/wsdl/\" xmlns:soap=\"http://schemas.xmlsoap.org/wsdl/soap/\" xmlns:tns=\"urn:$this->service_name\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:SOAP-ENC=\"http://schemas.xmlsoap.org/soap/encoding/\" xmlns=\"http://schemas.xmlsoap.org/wsdl/\">\n"; $headerWSDL.= "\n"; if (empty($this->class_name)) { throw new Exception('No class name.'); } $class = new ReflectionClass($this->class_name); if (!$class->isInstantiable()) { throw new Exception('Class is not instantiable.'); } $methods = $class->getMethods(); $portTypeWSDL = ''; $bindingWSDL = '\n\n"; $serviceWSDL = '\n\n$this->service_name.'Port" binding="tns:'.$this->service_name."Binding\">
$_SERVER['SERVER_NAME'].':'.$_SERVER['SERVER_PORT'].$_SERVER['PHP_SELF']."\" />\n
\n
\n"; $messageWSDL = ''; foreach ($methods as $method) { if ($method->isPublic() && !$method->isConstructor()) { $portTypeWSDL.= '\n".'\n$method->getName()."Response\" />\n\n"; $bindingWSDL.= '\n".'\n$this->service_name\" encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\" />\n\n\n$this->service_name\" encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\" />\n\n\n"; $messageWSDL.= '\n"; $parameters = $method->getParameters(); foreach ($parameters as $parameter) { $messageWSDL.= '\n"; } $messageWSDL.= "\n"; $messageWSDL.= '\n"; $messageWSDL.= '\n"; $messageWSDL.= "\n"; } } $portTypeWSDL.= "
\n"; $bindingWSDL.= "\n"; //return sprintf('%s%s%s%s%s%s', $headerWSDL, $portTypeWSDL, $bindingWSDL, $serviceWSDL, $messageWSDL, '
'); $fso = fopen($this->class_name . ".wsdl", "w"); fwrite($fso, sprintf('%s%s%s%s%s%s', $headerWSDL, $portTypeWSDL, $bindingWSDL, $serviceWSDL, $messageWSDL, '')); } /** * SoapDiscovery::getDiscovery() Returns discovery of WSDL. * * @return string **/ public function getDiscovery() { return "\n\n$_SERVER['SERVER_NAME'].':'.$_SERVER['SERVER_PORT'].$_SERVER['PHP_SELF']."?wsdl\" />\n"; } } ?> View Code

 

客户端:

client.php 代码:

=============================================================

<?<span>php
    </span><span>ini_set</span>('soap.wsdl_cache_enabled', "0"); <span>//</span><span>关闭wsdl缓存</span>


    <span>$soap</span> = <span>new</span> SoapClient('http://localhost/soap/service.php?wsdl'<span>);
    </span><span>echo</span> <span>$soap</span>->strtolink('http://www.baidu.com')."<br/>"<span>;
    </span><span>echo</span> <span>$soap</span>->add(28, 100)."<br/>"<span>;
    </span><span>echo</span> <span>$soap</span>->__soapCall('add',<span>array</span>(28,200))."<br/>"<span>;
    </span><span>//</span><span>或这样调用</span>
    <span>echo</span> <span>$soap</span>->__Call('add',<span>array</span>(28,300))."<br/>"<span>;
    </span><span>echo</span> <span>date</span>('Y-m-d H:i:s', <span>time</span><span>());

</span>?>

 

================ END====================

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1119777.htmlTechArticlePHP soap Web Service 使用SoapDiscovery.class.php 生成wsdl文件, PHP soap web service 使用wsdl文件 demo: ============================================================== 服...
Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn