wsdl php,在 PHP 中实现带 WSDL 的 SOAP

本文档介绍了如何利用Composer安装piotrooo/wsdl-creator库来创建WSDL文件,实现对外部接口的支持。通过创建一个名为Api的入口文件,设置SoapServer并指定接口类Notify。Notify类包含了实际的业务逻辑,其方法注释用于生成WSDL。此外,还展示了如何使用SoapUI进行接口调试,并强调了编写接口调用说明文档的重要性。
摘要由CSDN通过智能技术生成

用 composer 安装生成 WSDL 所需的库 composer require piotrooo/wsdl-creator

实现用于外部访问的入口文件,代码示例请参考(其中方法名和参数中出现的 Notify 对应一个类名,该类的方法将成为可以通过 SOAP 调用的外部接口): <?php

use WSDL\DocumentLiteralWrapper;

use WSDL\WSDLCreator;

use WSDL\XML\Styles\DocumentLiteralWrapped;

class Api

{

public static function soapNotify()

{

$host = $_SERVER['HTTP_HOST'];

$soapuri = "http://{$host}/Api/soapNotify";

if (isset($_GET['wsdl'])) {

$wsdl = new WSDLCreator('Notify', $soapuri);

$wsdl->renderWSDL();

exit;

}

$server = new SoapServer(null, [

'uri' => $soapuri

]);

$server->setClass('Notify');

$server->handle();

}

}

实现包含接口功能逻辑的类文件,代码示例请参考(其中方法的注释相当重要,是 wsdl-creator 正确生成 WSDL 的依据,必须严格按照格式进行注释): class Notify

{

/**

* @desc sendText 向患者的微信发送文本信息

* @param string $toUser 发给哪个用户

* @param string $content 发送的内容

* @return string $result

*/

public function sendText($toUser, $content)

{

if (!$toUser || !$content) {

return E::INVALID;

}

$user = G::xpdo()->row("SELECT * FROM `users` WHERE `patientid` = ?", [$toUser]);

if (!$user) {

return E::NODATA;

}

$api = G::xpdo()->row("SELECT * FROM `api` WHERE `token` = ?", [$user['token']]);

$weixin = new Weixin($api['appid'], $api['appsecret']);

$weixin->sendText($user['openid'], $content);

return 0;

}

}

使用 SoapUI 软件对接口进行调试

编制相应的接口调用说明文档

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值