1.注册快递100账号,获取key和公司编号

注:快递100基础版不支持主流快递,如三通一达、顺丰、京东、EMS、德邦、天天、百世、邮政等主流快递的查询。企业版支持所有快递,且有100单的免费测试。

我注册的是企业版的。

注册成功后,从这里获取key和customer(公司编号)用于接口使用

可以查看接口信息,能使用那些功能,下图是企业版拥有的功能

我只是用到其中圈红的三个接口

2.接口使用简单讲解

(1)智能判断接口:输入一个正确的物流单号,可以智能的判断属于哪个快递公司的物流单号,获取相应快递公司的编码,用于实时查询接口和订阅推送接口

返回智能识别的结果可能有多个结果也可能没有结果,这边业务使用时需要判断一下

返回结果为多个时,我一般取第一个(可能性最大)

(2)实时查询接口:顾名思义,手动的去实时查询物流的最新动态

参数注意一下这几个必填的,还有查顺丰的单号时手机号必填,其他的看情况去设置参数即可

快递公司编码是智能识别出的公司编码,当然如果知道要查询的快递是哪个公司的快递,可以不使用智能识别接口

快递公司编码下载

返回结果:

对快递单号状态的解释:

我当前项目中没有对快递状态进行处理,只是展示快递的信息给用户

(3)订阅推送接口:跟项目结合的更紧密一点,通过订阅某个物流单号,当订阅的单号物流状态更新后,通过设定的回调地址异步的通知项目,这样就可以不必实时的请求快递100的实时查询物流接口

有好处也有不好的地方,需要自己去设计数据库,存储和展示,后期准备把项目改成这样,当然需要结合项目的业务逻辑去实现。

参数比较多:但是只需要看必需的参数和顺丰单号特殊处理手机号就行,其他参数是选填

订阅的快递公司编码是智能识别出的公司编码,当然如果知道要查询的快递是哪个公司的快递,可以不使用智能识别接口

快递公司编码下载

回调地址是你项目的回调地址,不要弄错了

返回信息中查看lastResult中的state:快递单号状态、ischeck:是否签收标记、data:物流信息数组,data里面有多个物流信息,第一个是最新的。

3.接口封装为类和回调处理

class Logistics
{/*** 客户授权key* @var string*/protected $key = '';/*** 查询公司编号* @var string*/protected $customer = '';/*** 智能判断快递公司编码* @param $num* @return array|mixed*/public function autoNumber($num){if (empty($num)) return [];//智能判断请求地址$url = 'http://www.kuaidi100.com/autonumber/auto';$post_data = array();$post_data['key'] = $this->key;$post_data['num'] = $num;$params = $this->urlEncodeParam($post_data);$result = $this->curlRequest($url, $params);return $result[0] ?? [];}/*** 订阅请求* @param $num* @return mixed*/public function subscribe($num){//订阅请求地址$url = 'http://poll.kuaidi100.com/poll';$type = $this->autoNumber($num);if (!isset($type['comCode']) || empty($type['comCode'])) return [];//参数设置$param = array('company' => $type['comCode'],     //快递公司编码'number' => $num,                  //快递单号'from' => '',                     //出发地城市'to' => '',                       //目的地城市'key' => $this->key,              //客户授权key'parameters' => array('callbackurl' => 'http://www.solveset.net/api/logisticsNotify',//回调地址'salt' => '',                 //加密串'resultv2' => '1',            //行政区域解析'autoCom' => '0',             //单号智能识别'interCom' => '0',            //开启国际版'departureCountry' => '',     //出发国'departureCom' => '',         //出发国快递公司编码'destinationCountry' => '',   //目的国'destinationCom' => '',       //目的国快递公司编码'phone' => ''                 //手机号));//请求参数$post_data = array();$post_data['schema'] = 'json';$post_data['param'] = json_encode($param);$params = $this->urlEncodeParam($post_data);return $this->curlRequest($url, $params);}/*** 实时查询* @param $num* @return mixed*/public function nowQuery($num){//实时查询请求地址$url = 'http://poll.kuaidi100.com/poll/query.do';$type = $this->autoNumber($num);if (!isset($type['comCode']) || empty($type['comCode'])) return [];//参数设置$param = array('com' => $type['comCode'],    //快递公司编码'num' => $num,                //快递单号'phone' => '',                //手机号'from' => '',                 //出发地城市'to' => '',                   //目的地城市'resultv2' => '1'             //开启行政区域解析);//请求参数$post_data = array();//查询公司编号$post_data['customer'] = $this->customer;$post_data['param'] = json_encode($param);$sign = md5($post_data['param'] . $this->key . $post_data['customer']);$post_data['sign'] = strtoupper($sign);$params = $this->urlEncodeParam($post_data);return $this->curlRequest($url, $params);}/*** 对参数进行urlencode* @param $data* @return bool|string*/protected function urlEncodeParam($data){$params = '';foreach ($data as $k => $v) {$params .= $k . '=' . urlencode($v) . '&';//默认UTF-8编码格式}$data = substr($params, 0, -1);return $data;}/*** curl请求* @param $url* @param $post_data* @return mixed*/protected function curlRequest($url, $post_data){$ch = curl_init();curl_setopt($ch, CURLOPT_POST, 1);curl_setopt($ch, CURLOPT_HEADER, 0);curl_setopt($ch, CURLOPT_URL, $url);curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data);curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);$result = curl_exec($ch);$data = str_replace("\"", '"', $result);return json_decode($data, true);}
}

调用:

$obj = new Logistics();
print_r($obj->nowQuery('123123'));
//print_r($obj->subscribe('123123'));

回调处理

路由:使用的是laravel框架

//物流订阅回调
Route::any('/api/logisticsNotify', 'Api\ApiTestController@logisticsNotify');

业务处理

//测试物流订阅回调public function logisticsNotify(){$body = file_get_contents('php://input');if (!empty($body)) {//url解码$body_str = urldecode($body);$data_str = substr($body_str, strpos($body_str, 'param=') + 6);if (!empty($data_str)) {//json字符串转换为数组格式$data = djson($data_str);//处理逻辑iF(!empty($data)) {//快递单状态 0在途,1揽收,2疑难,3签收,4退签,5派件,6退回if($data['lastResult']['state'] == 3) {//订单状态修改为已收货}}//记录日志$filePath = createLogFile('logisticsNotify.log', 'logs/solve');file_put_contents($filePath, '物流单号异步通知:' . var_export($data, true), FILE_APPEND);}}//返回成功状态echo json(['result' => true, 'returnCode' => 200, 'message' => '成功']);}

日志中的记录

到目前为止,只是简单的解释了三个接口,写了一个demo,但是大概思路和流程是完善的,是对项目使用快递100的一个整理和备忘。

快递100接口使用整理相关推荐

  1. 快递100接口查询限制分析

    前言 最近,发现快递100快递明细查询接口异常(https://www.kuaidi100.com/query?type=jd&postid=快递单号&temp=0.478258924 ...

  2. 快递100接口的简单使用:

    上篇播客,介绍了容联云通信短信接口的应用,并且封装过cURL的函数 , 在这里介绍一下快递100接口的简单应用,再次封装一个cURL发送方法写出:如果不想用这个函数,也可以使用file_get_con ...

  3. 快递100接口的调用过程

    前言 大部分的商城都需要调用快递的接口来记录商城的物流信息,这里就给出一种快递接口(快递100)调用的方法. 正文 一.官方文档 1. 官方文档的地址为: https://www.kuaidi100. ...

  4. 顺丰快递商家寄件发货接口API类型和接入流程方案【快递100接口Demo】

    顺丰快递对于商家和个人的隐私保护较为严格,对于操作频次高的用户会进行多次验证码确认信息和服务安全.如果需要大量地邮寄顺丰快递以及查询顺丰的快递物流轨迹信息,必须对接顺丰官方的寄件和查询API接口.企业 ...

  5. 快递100接口对接总结

    免费版; (1)当天最多调用2000次; (2)仅支持在线查询: (3)仅支持200家,不支持国际. 企业版: (1)次数无限制: (2)支持主动推送.智能快递归属分析.实时查询: (3)支持快递公司 ...

  6. 快递鸟 快递100接口示例

    <?php$KdApi=new KdApi(); // //调用快递鸟查询物流轨迹 // //--------------------------------------------- // / ...

  7. 【快递100接口BUG】数据库时区为0时区,而实际时区为东八区时间,导致存入时间多出八个小时

    前些天,上线了快递100的订阅推送服务. 运行稳定,今天早上,运维忽然跟我说,快递单穿越未来了. 我愣了一下,然后运维发了一张图. 说实话,当时我是懵逼的. 因为这个12月03号,下午17:55分还没 ...

  8. 快递100接口 使用

    怎么对接快递 物流信息接口  一下是代码 仅供参考 public function kuaidi100($type,$num){// $order_info['post_type'] = 'yuant ...

  9. java快递100接口开发_java swing开发的一个抓取快递100查询接口的小工具

    package com.ccg.util; import java.io.BufferedReader; import java.io.File; import java.io.FileInputSt ...

最新文章

  1. 只需1秒,无人机就能平地翻跟头 | IEEE
  2. 二周第一次课(12月18日)
  3. mysql联合查询数量不一致_Mybatis关联查询,查询出的记录数量与数据库直接查询不一致,如何解决?...
  4. Linux下网络编程
  5. IBM押注沃森人工智能技术 未来6年或达170亿美元
  6. Java设计模式(十一):组合设计模式
  7. oracle数据表空间与数据文件,oracle 操作表空间和数据文件
  8. 桌面整理工具不显示文件夹_iOS14系统所下载的软件图标不显示在桌面怎么办?...
  9. python接口自动化发送get请求 详解(一)
  10. UE4中Component和Subobject的区别
  11. Linux系统Bash(Shell)基础知识(4)
  12. STL算法之 copy、copy_backward、copy_n
  13. i.MX6ULL终结者MPU6050 六轴传感器例程MPU6050简介
  14. 我是一个大器晚成的投资人
  15. 语言学及应用语言学类毕业论文文献有哪些?
  16. 逆水寒服务器维护26号,逆水寒维护到几点 逆水寒8.23维护公告时间
  17. Oracle 删除数据后释放数据文件所占磁盘空间(表空间降高水位)
  18. 正式揭牌!华为与清华北大、中科院共建博士后工作站!
  19. MySQL 数据库重启
  20. 恒大造车,从来都不是梦

热门文章

  1. Vagrant在,win7/win10系统下搭建使用
  2. 需要密码才能打开的word文件
  3. python运用在大数据中精准生活_大数据分析技术在生活中的广泛应用
  4. amigo幸运字符什么意思_超不清视频播放器-用Python将视频转成字符
  5. coding码市管理项目
  6. python模拟登录钉钉,Python—实现钉钉后台开发,
  7. 前端页面生成神器以及后端变量命名神器
  8. 史上最详细的LXR安装介绍
  9. 关于如何在chrome中下载网页flash视频
  10. Kaggle项目之Mobile App Store