PHP快递单号查询接口源码指导 (快递鸟API)

简介: 背景最近进行网站后台开发,需要实现物流的即时查询, 为了方便以后的业务需求,经过比较,最后选择使用第三方快递查询接口服务商 ——【快递鸟】同时,在此进行整理,希望能帮到有需求的道友们,谢谢 ...官方文档: 快递鸟 —— 即时查询API开发框架:ThinkPHP5.1.2 开发步骤①. 前期准备首先要进行快递鸟账号的注册快递单号查询接口_电子面单_APIKey授权申请-快递鸟账号注册快递鸟API key免费注册并根据对方的要求,完善用户申请。

背景

最近进行网站后台开发,需要实现物流的即时查询, 为了方便以后的业务需求,经过比较,最后选择使用第三方快递查询接口服务商 ——【快递鸟】
同时,在此进行整理,希望能帮到有需求的道友们,谢谢 ...
官方文档: 快递鸟 —— 即时查询API
开发框架:ThinkPHP5.1.2
开发步骤

①. 前期准备
首先要进行快递鸟账号的注册

快递单号查询接口_电子面单_APIKey授权申请-快递鸟账号注册

快递鸟API key免费注册

并根据对方的要求,完善用户申请。
然后,根据自己的需求,开通所需服务(如果只是进行物流信息的查询,以当前业务查询次数较少为例):

②. 集成类的使用
首先需要登录 快递鸟 ,获取账号的 用户ID和 API key
注册完成后登入,进入到个人中心,这里需要进行一个实名认证,按公司产品的类型进行一个选择,展示页面如下图

快递鸟实名认证
认证完成后在我的产品服务中选择自己所需要的服务,当然对于初创型公司来说选择免费版就够了,等到业务做大时再选择其他产品服务

还有就是在个人中心中如下图所示,我们需要记住的是用户ID,和API key(不要泄露),这将是我们进行接口调用时需要用到的,

对所提供源码中的 集成类 BirdExpress.php,进行配置项的==替换操作==

然后
将集成类整合到你的项目框架,根据框架规则进行必要修改(框架不同规则自然多数不同,本人为 ThinkPHP5.1.2)
下图为简单的调用测试:

③. 核心处理方法源码

首先,官方的代码 demo获得的物流信息是==正序展示==的
为了方便物流信息的倒序展示,我进行了对数组Traces的==反转操作==

/**
 * 核心方法
 * Json方式 查询订单物流轨迹
 * @param string $ShipperCode 快递公司编码
 * @param string $LogisticCode 物流单号
 * @param int $arrayFlag 是否进行数组转化标志 默认0:否  1:转化
 * 参考规则举例:
 * $requestData = "{'OrderCode':'','ShipperCode':'ZTO','LogisticCode':'640041334612'}";
 * @return result 包含即时物流信息的 Json数据
 */
public function getOrderTracesByJson($ShipperCode = "",$LogisticCode = "",$arrayFlag = 0)
{
    $requestData = "{   
                        'OrderCode':'',
                        'ShipperCode':'$ShipperCode',
                        'LogisticCode':'$LogisticCode'
                    }";
    $postData = array(
        'EBusinessID' => $this->EBusinessID,
        'RequestType' => '1002',//接口指令1002
        'RequestData' => urlencode($requestData),
        'DataType' => '2',
    );
    $postData['DataSign'] = $this->encrypt($requestData, $this->AppKey);
    $result = $this->sendPost($this->ReqURL, $postData);
    //根据公司业务处理返回的信息......
    if ($arrayFlag){
        $result = json_decode($result,true);
        //TODO 方便物流信息的倒序展示,进行数组反转
        $result['Traces'] = array_reverse($result['Traces']);
    }
    return $result;
}

④. 效果展示截图

通过上面核心源码的展示,你应该会注意到
调用其方法,必须要传入 ==快递公司编码== 和 ==物流单号== 这两个参数
好在,官方提供了 快递公司编码, 所以,鄙人的设计思路如下:

  1. 根据官方提供的快递公司编码Excel表,取出其中的 "快递公司"和"编码"两列数据存储到本地数据表 ,如果使用的快递数量较集中,可以自己建表输入 ,如果是通用性的快递使用,建议直接对excel表转化为mysql(或其他数据表)存储

如果需要进行 excel表的导入操作,可直接参考对应文章: ThinkPHP5.1 excel表的导入导出操作 (PHPExcel)

  1. 在后台操作人员输入快递单号时 同时要求选择快递公司,获得 "编码" 从而保证,在数据表中,存储的快递单号唯一匹配到一个编码,继而方便后面进行快递信息查询时,可同时获得所需的两个参数。

源码上传 >>>

附录
为什么我选择使用快递鸟API

首先,我拥有一个,测试物流单号:640041334612 (中通快递),然后使用多个快递查询服务,效果如下:

通過比較发现:

  1. "快递100" 没有查到结果; "爱查快递" 得出的结果并不是真实的物流信息
  2. "快递网" 能查到快递信息,但是询问服务人员时知晓: 要么网站上添加对方链接(我的管理后台以及小程序、app是不能这样玩的);要么需要进行套餐定制,最低的大概一年1000 —— (前期网站是不需要那么大的 查询业务的,感觉浪费),而且,我不喜欢官网的设计风格(任性了)
  3. "快递鸟",最让我动心的是那个 "限3000次/天(即时查询)" 是免费的 , 对于业务量前期不大的网站足够使用,即便后期有需要,也可以直接进行套餐升级
目录
相关文章
|
6天前
|
API 数据安全/隐私保护
单页源码加密屋zip文件加密API源码
单页源码加密屋zip文件加密API源码 api源码里面的参数已改好,往服务器或主机一丢就行,出现不能加密了就是加密次数达到上限了,告诉我在到后台修改加密次数
12 1
|
15天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
【4月更文挑战第29天】本文探讨了在Web开发中流行的前后端分离模式,重点介绍了RESTful API的设计与实现。REST是一种基于HTTP协议的架构风格,核心概念包括资源、表述和状态转换。RESTful API设计遵循无状态、统一接口等原则,使用GET、POST、PUT、DELETE等HTTP方法执行操作,并通过状态码和JSON/XML传输数据。在PHP中实现RESTful API,可通过定义路由、创建控制器、处理请求和响应,同时注意安全性措施,如使用HTTPS。文中还提供了一个用户管理API的实战示例,以帮助读者更好地理解和应用RESTful API。
|
15天前
|
XML JSON API
快速淘宝商品详情页面API接口传输 php
PI(Application Programming Interface,应用程序接口)是一组预定义的函数、协议和工具,用于构建软件应用程序之间的交互。它允许不同的软件系统和应用通过统一的接口进行数据交换和通信
|
15天前
|
存储 监控 BI
HIS系统是什么?一套前后端分离云HIS系统源码 接口技术RESTful API + WebSocket + WebService
医院管理信息系统(全称为Hospital Information System)即HIS系统。 常规模版包括门诊管理、住院管理、药房管理、药库管理、院长查询、电子处方、物资管理、媒体管理等,为医院管理提供更有力的保障。 HIS系统以财务信息、病人信息和物资信息为主线,通过对信息的收集、存储、传递、统计、分析、综合查询、报表输出和信息共享,及时为医院领导及各部门管理人员提供全面、准确的各种数据。 门诊医生工作站采用下拉式汉化菜单,界面友好,实用性强,设有与门诊挂号收费系统、医技科室信息系统、住院结算信息系统的软件接口。
40 1
|
15天前
|
JSON API 数据安全/隐私保护
1688阿里巴巴中国站获得商品快递费用 API接口
阿里巴巴1688中国站提供了丰富的API接口供开发者使用,以获取商品信息、订单详情、物流费用等。然而,关于获取商品快递费用的具体API接口,可能会因阿里巴巴平台的更新而有所变化。
|
15天前
|
Java API PHP
多多关键字API php java Python
多多关键字API接口广泛应用于商家进行市场分析、竞品分析、关键词优化等场景。商家可以通过分析关键词数据,了解用户需求,制定针对性的营销策略,提高产品的曝光率和转化率。
|
15天前
|
移动开发 API HTML5
HTML5响应式自动采集API壁纸系统源码自适应手机端
HTML5响应式自动采集API壁纸系统源码自适应手机端
44 11
HTML5响应式自动采集API壁纸系统源码自适应手机端
|
15天前
|
Java API 时序数据库
InfluxData【付诸实践 02】SpringBoot 集成时序数据库 InfluxDB 应用分享(InfluxDB实例+Feign接口调用InfluxDB API)源码分享
InfluxData【付诸实践 02】SpringBoot 集成时序数据库 InfluxDB 应用分享(InfluxDB实例+Feign接口调用InfluxDB API)源码分享
87 0