ibrand/laravel-express:快递信息查询
特点
一套写法兼容所有平台 简单配置即可灵活增减服务商 统一的返回值格式,便于日志与监控TODO:
支持更多快递信息查询平台
目前平台支持
快递100安装
composer require "ibrand/laravel-express"
低于 Laravel5.5 版本:
config/app.php
文件providers
数组中添加:
iBrandExpressServiceProvider::class
config/app.php
文件aliases
数组总 添加:
'Express'=> iBrandExpressFacade::class
如需自定义配置请执行:
php artisan vendor:publish --provider="iBrandExpressServiceProvider"
使用
实现了查询快递信息路由,支持web
和api
,可以自定义prefix:
'route' => [ 'prefix' => 'express', 'middleware' => ['web'], ], //or 'route' => [ 'prefix' => 'express', 'middleware' => ['api'], ],
GET请求http://your.domain/express/query
参数:no 快递单号
返回结果:
{ "kuaidi100": { "gateway": "kuaidi100", "status": "success", "result": [ { "time": "2019-01-09 14:16:41", "ftime": "2019-01-09 14:16:41", "context": "[长沙市]已签收,感谢使用顺丰,期待再次为您服务" }, { "time": "2019-01-09 09:03:41", "ftime": "2019-01-09 09:03:41", "context": "[长沙市]收方客户要求自取快件,待自取" }, { "time": "2019-01-09 08:44:17", "ftime": "2019-01-09 08:44:17", "context": "[长沙市]快件交给周逢平,正在派送途中(联系电话:13017295338)" }, { "time": "2019-01-08 16:00:50", "ftime": "2019-01-08 16:00:50", "context": "[长沙市]快件到达 【长沙浏阳东沙新村营业点】" }, { "time": "2019-01-08 14:28:28", "ftime": "2019-01-08 14:28:28", "context": "[长沙市]快件已发车" }, { "time": "2019-01-08 14:17:02", "ftime": "2019-01-08 14:17:02", "context": "[长沙市]快件在【长沙星沙集散中心】已装车,准备发往 【长沙浏阳东沙新村营业点】" }, { "time": "2019-01-08 13:57:56", "ftime": "2019-01-08 13:57:56", "context": "[长沙市]快件到达 【长沙星沙集散中心】" }, { "time": "2019-01-08 12:51:04", "ftime": "2019-01-08 12:51:04", "context": "[长沙市]快件已发车" }, { "time": "2019-01-08 11:46:44", "ftime": "2019-01-08 11:46:44", "context": "[长沙市]快件在【长沙岳麓银盆岭营业点】已装车,准备发往下一站" }, { "time": "2019-01-08 11:00:39", "ftime": "2019-01-08 11:00:39", "context": "[长沙市]顺丰速运 已收取快件" } ] } }
你也可以通过使用Facade
来查询快递信息
use Express; Express::query(request('no'));
默认使用 default
中的设置来发送,如果你想要覆盖默认的设置。在 query
方法中使用第二个参数即可:
use Express; Express::query((request('no'), ['aliyun']); // 这里的网关配置将会覆盖全局默认,需要在配置文件中配置好相关项
也可以这样:
use Express; Express::query((request('no'), ['aliyun'=>[ 'app_key' => '', 'app_secret' => '', 'app_code' => '', ]]);
查询网关
默认使用 default
中的设置来发送,如果你想要覆盖默认的设置。在 query
方法中使用第二个参数即可:
use Express; $number = '810597623758'; Express::query($number, ['kuaidi100']); // 这里的网关配置将会覆盖全局默认值
返回值
由于使用多网关发送,所以返回值为一个数组,结构如下:
[ 'kuaidi100' => [ 'gateway' => 'kuaidi100', 'status' => 'success', 'result' => [...] // 平台返回值 ], 'aliyun' => [ 'gateway' => 'aliyun', 'status' => 'failure', 'exception' => Exception 对象 ], //... ]
如果所选网关列表均发送失败时,将会抛出 Exception
异常,你可以使用 $e->results
获取发送结果。
各平台配置说明
快递100
'kuaidi100' => [ 'key' => '', 'customer' => '', 'secret' => '', 'sms_user_id' => '' ],
版权声明:
1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。2、网站不提供资料下载,如需下载请到原作者页面进行下载。
3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考学习用!
4、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。