ibrand/laravel-express:快递信息查询

ibrand/laravel-express:快递信息查询

特点

  1. 一套写法兼容所有平台
  2. 简单配置即可灵活增减服务商
  3. 统一的返回值格式,便于日志与监控

TODO:

支持更多快递信息查询平台

目前平台支持

安装

composer require "ibrand/laravel-express"

低于 Laravel5.5 版本:

config/app.php文件providers数组中添加:

iBrand\Express\ServiceProvider::class

config/app.php 文件aliases数组总 添加:

'Express'=> iBrand\Express\Facade::class

如需自定义配置请执行:

php artisan vendor:publish --provider="iBrand\Express\ServiceProvider"

使用

实现了查询快递信息路由,支持webapi,可以自定义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' => ''    ],
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值