PHP使用第三方即時獲取物流動態(tài)實例詳解
前言
最近做的項目有個要求,要使用物流單號即時查詢物流信息,從網(wǎng)上得知,關于物流的第三方API還是很多的,而我選用的是快遞鳥,快遞鳥是一個免費的第三方接口,Api整合全球400余家物流快遞接口,永久免費不限次,接口與快遞公司多通道通信,可用性達到99.9%以上,推送速度定制配置,保證接入方系統(tǒng)的穩(wěn)定。
使用過程
登錄網(wǎng)站http://www.kdniao.com/首先要注冊,注冊完之后,在用戶管理后臺,有一個申請API選項,注意,申請API之前需要實名認證,認證完之后就可以申請API了,它的API接口還是很豐富的。
因為我要是用的是即時查詢,所以申請的就是即時查詢的api。
api的使用流程圖
從流程圖中可以看到
用戶只要提供快遞單號和快遞公司
通過api得到物流狀態(tài),并把結(jié)果返回
我們拿到結(jié)果,進行實時處理顯示。
API參數(shù)
上面這些都是官方給出的關于API的參數(shù),不過我們可以看官方的demo進行了解。官方的demo也是簡單易懂的。我們可以把它再次封裝。
封裝API
使用API需要三個固定參數(shù)
1. 商戶id
2. API key
3. 請求url,ReqURL
商戶id和API key都可以在快遞鳥網(wǎng)站的我的管理首頁看到,而請求url就是
http://api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx,這個可以在接口文檔中看到。
主方法
/** * @param $ShipperCode 快遞公司編號 * @param $order_sn 運單號 */ public function getMessage($ShipperCode,$order_sn){ $requestData= "{'OrderCode':'','ShipperCode':'".$ShipperCode."','LogisticCode':'".$order_sn."'}"; $datas = array( 'EBusinessID' => self::EBusinessID, 'RequestType' => '1002',//接口指令1002,固定 'RequestData' => urlencode($requestData) , 'DataType' => '2', //數(shù)據(jù)返回格式 2 json ); //把$requestData進行加密處理 $datas['DataSign'] = $this -> encrypt($requestData, self::AppKey); $result = $this -> sendPost( self::ReqURL, $datas); return $result; }
這主方法中,傳遞進去的參數(shù)有兩個,一個是快遞公司編號,一個是物流訂單號。
我們還需要把$requestData進行加密處理,也就是encrypt方法。
/* * 進行加密 */ function encrypt($data, $appkey) { return urlencode(base64_encode(md5($data.$appkey))); }
加密過后就直接通過ReqURL進行訪問,返回的數(shù)據(jù)就是物流信息。
源代碼
<?php /** * 使用快遞鳥api進行查詢 * User: Administrator * Date: 2017/4/22 0022 * Time: 09:09 */ class KuaidiController{ const EBusinessID = 1285564; const AppKey = '264ff9e0-2f4c-48d5-877f-1e0670400d18'; const ReqURL = "http://api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx"; /** * @param $ShipperCode 快遞公司編號 * @param $order_sn 運單號 */ public function getMessage($ShipperCode,$order_sn){ $requestData= "{'OrderCode':'','ShipperCode':'".$ShipperCode."','LogisticCode':'".$order_sn."'}"; $datas = array( 'EBusinessID' => self::EBusinessID, 'RequestType' => '1002',//接口指令1002,固定 'RequestData' => urlencode($requestData) , 'DataType' => '2', //數(shù)據(jù)返回格式 2 json ); //把$requestData進行加密處理 $datas['DataSign'] = $this -> encrypt($requestData, self::AppKey); $result = $this -> sendPost( self::ReqURL, $datas); return $result; } /** * post提交數(shù)據(jù) * @param string $url 請求Url * @param array $datas 提交的數(shù)據(jù) * @return url響應返回的html */ function sendPost($url, $datas) { $temps = array(); foreach ($datas as $key => $value) { $temps[] = sprintf('%s=%s', $key, $value); } $post_data = implode('&', $temps); $url_info = parse_url($url); if(empty($url_info['port'])) { $url_info['port']=80; } $httpheader = "POST " . $url_info['path'] . " HTTP/1.0\r\n"; $httpheader.= "Host:" . $url_info['host'] . "\r\n"; $httpheader.= "Content-Type:application/x-www-form-urlencoded\r\n"; $httpheader.= "Content-Length:" . strlen($post_data) . "\r\n"; $httpheader.= "Connection:close\r\n\r\n"; $httpheader.= $post_data; $fd = fsockopen($url_info['host'], $url_info['port']); fwrite($fd, $httpheader); $gets = ""; $headerFlag = true; while (!feof($fd)) { if (($header = @fgets($fd)) && ($header == "\r\n" || $header == "\n")) { break; } } while (!feof($fd)) { $gets.= fread($fd, 128); } fclose($fd); return $gets; } /* * 進行加密 */ function encrypt($data, $appkey) { return urlencode(base64_encode(md5($data.$appkey))); } } $model = new KuaidiController(); $res = $model -> getMessage('ZTO','12345678'); echo "<pre>"; var_dump($res);
以上所述是小編給大家介紹的PHP使用第三方即時獲取物流動態(tài),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
php curl請求接口并獲取數(shù)據(jù)的示例代碼
本篇文章主要介紹了php curl請求接口并獲取數(shù)據(jù)的示例代碼,非常具有實用價值,需要的朋友可以參考下2017-08-08Zend Framework教程之配置文件application.ini解析
這篇文章主要介紹了Zend Framework教程之配置文件application.ini用法,分析了配置文件application.ini中常見的配置項含義及用法,需要的朋友可以參考下2016-03-03PHP基于CURL進行POST數(shù)據(jù)上傳實例
這篇文章主要介紹了PHP基于CURL進行POST數(shù)據(jù)上傳的方法,以完整的實例形式較為詳細的講述了PHP采用curl進行POST數(shù)據(jù)傳遞的方法,具有一定的參考借鑒價值,需要的朋友可以參考下2014-11-11Centos6.5和Centos7 php環(huán)境搭建方法
這篇文章主要介紹了Centos6.5和Centos7 php環(huán)境搭建方法的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-05-05