快遞即時(shí)查詢api接口功能詳解攻略

      網(wǎng)友投稿 1024 2022-05-30

      1>.注冊快遞鳥賬號(hào),

      API_ID:XXXXXX

      API_KEY:XXXXXXXXXXXXXXXXXX

      2>.服務(wù)申請

      在個(gè)人中心里面申請需要的服務(wù),即時(shí)查詢功能有免費(fèi)的服務(wù)

      3>.對(duì)接服務(wù)

      ***寫自己的業(yè)務(wù)邏輯***----本文主體

      4>.測試代碼

      5>.正式使用

      (二)、接口描述/說明

      (1)查詢接口支持按照運(yùn)單號(hào)查詢(單個(gè)查詢)。

      (2)接口需要指定快遞單號(hào)的快遞公司編碼,格式不對(duì)或則編碼錯(cuò)誤都會(huì)返失敗的信息。

      如:EMS物流單號(hào)應(yīng)選擇快遞公司編碼(EMS)查看快遞公司編碼

      (3)返回的物流跟蹤信息按照發(fā)生的時(shí)間升序排列。

      (4)接口指令1002。

      (5)接口支持的消息接收方式為HTTP POST,請求方法的編碼格式(utf-8):“application/x-www-form-urlencoded;charset=utf-8”。

      (6)測試地址:http://sandboxapi.kdniao.com:8080/kdniaosandbox/gateway/exterfaceInvoke.json

      (7)正式地址:http://api.kdniao.com/Ebusiness/EbusinessOrderHandle.aspx

      (三)必傳參數(shù)說明:

      請求內(nèi)容:

      OrderCode:訂單編號(hào)—非必須

      ShipperCode:快遞公司編碼—必須

      LogisticCode:物流單號(hào)—必須

      系統(tǒng)參數(shù)

      RequestData:將JSON格式請求內(nèi)容進(jìn)行URL(utf-8)編碼;

      EBusinessID:API_ID;

      RequestType:1002;

      DataSign:請求內(nèi)容(未編碼)+AppKey)進(jìn)行MD5加密,然后Base64編碼,最后 進(jìn)行URL(utf-8)編碼

      先上圖,看結(jié)果:

      技術(shù)文檔請參考快遞鳥官網(wǎng)api:https://www.kdniao.com/api-track

      快遞公司編碼鏈接:https://www.kdniao.com/file/2019快遞鳥接口支持快遞公司編碼.xlsx

      快遞鳥即時(shí)查詢api接口功能詳解攻略

      (四)功能封裝

      *省去了導(dǎo)包語句,根據(jù)自己情況添加

      #?請求數(shù)據(jù)處理 def?organize_request_data(shipper_code,?logistic_code):????"""編碼請求數(shù)據(jù)""" ????original_request_data?=?{????????"OrderCode":?"",??#?默認(rèn)設(shè)置為空????????"ShipperCode":?shipper_code,????????"LogisticCode":?logistic_code,????????"IsHandleInfo":?"0" ????} ????#?數(shù)據(jù)轉(zhuǎn)換為json格式 ????data?=?json.dumps(original_request_data) ???? ????#?進(jìn)行url編碼 ????#?這里有個(gè)坑,有興趣的可以試試 ????#??request_data?=?quote(data),二者還是有區(qū)別的 ????request_data?=?quote(data).replace("%20%",?"%") ????return?request_data def?generate_data_sign(shipper_code,?logistic_code): """生成datasign""" ????original_request_data?=?{ ????????'OrderCode':?'', ????????'ShipperCode':?shipper_code, ????????'LogisticCode':?logistic_code,????????"IsHandleInfo":?"0" ????} ????#?APP_KEY?=?API_KEY_PRO ????APP_KEY?=?API_KEY_PRO ????#?請求內(nèi)容(未編碼)?+?AppKey ????#?此處有另一個(gè)坑,關(guān)于MD5加密,字典中存不存在空格,結(jié)果并不一樣,而對(duì)于此接口,需要去除空格 ????data?=?json.dumps(original_request_data).replace(":?",?":").replace(",?",?",")?+?APP_KEY ????#?md5加密 ????sign_md5?=?hashlib.md5(data.encode("utf-8")).hexdigest() ????#?Base64編碼 ????data_sign?=?base64.b64encode(sign_md5.encode("utf-8")).decode("utf-8") ????return?data_sign

      視圖邏輯:

      class?CompanyView(LoginRequiredView): ????"""快遞公司編碼展示""" ????def?get(self,?request): ????????company_qs?=?KDCompany.objects.all() ????????company_list?=?[]????????for?company?in?company_qs: ????????????company_list.append({????????????????"name":?company.name,????????????????"code":?company.code ????????????})????????return?http.JsonResponse({'code':?RETCODE.OK,?'errmsg':?'OK',?'company_list':?company_list})class?KD(LoginRequiredView): ????"""展示快遞詳情""" ????def?post(self,?request): ????????shipper_codes?=?request.POST.get('shipper_code')????????#?由于前端代碼的XX,此處需處理取得的數(shù)據(jù),以取得所需的code ????????shipper_code=shipper_codes.split("?")[0] ????????logistic_code?=?request.POST.get('logistic_code') ????????request_data?=?organize_request_data(shipper_code,?logistic_code) ????????data_sign?=?generate_data_sign(shipper_code,?logistic_code) ????????API_ID?=?API_ID_PRO ????????API_URL?=?API_URL_PRO ????????data?=?{????????????"RequestData":?request_data,????????????"DataSign":?data_sign,????????????"RequestType":?"1002",????????????"EBusinessID":?API_ID,????????????"ShipperCode":?shipper_code,????????????"LogisticCode":?logistic_code,????????????"DataType":"2" ????????} #?按要求設(shè)置請求頭信息 ????????headers?=?{'content-type':?'application/x-www-form-urlencoded','content-Encoding':?'charset=utf-8'} ????????kd_response?=?requests.post(url=API_URL,?data=data,headers=headers) ????????kd_response.encoding="utf-8" ????????trace_resp=json.loads(kd_response.content).get("Traces") ????????trace_black?=?"" ????????traces?=?trace_black?if?type(trace_resp)?==?"NoneType"?else?trace_resp ????????context?=?{????????????"ShipperCode":?shipper_code,????????????"LogisticCode":?logistic_code,????????????"kd_response":traces ????????}????????return?render(request,?'kd_trace.html',?context)

      API

      版權(quán)聲明:本文內(nèi)容由網(wǎng)絡(luò)用戶投稿,版權(quán)歸原作者所有,本站不擁有其著作權(quán),亦不承擔(dān)相應(yīng)法律責(zé)任。如果您發(fā)現(xiàn)本站中有涉嫌抄襲或描述失實(shí)的內(nèi)容,請聯(lián)系我們jiasou666@gmail.com 處理,核實(shí)后本網(wǎng)站將在24小時(shí)內(nèi)刪除侵權(quán)內(nèi)容。

      上一篇:Deepin 下 使用 Rider 開發(fā) .NET Core
      下一篇:【案例分享】MapReduce Service OMS頻繁主備倒換manager界面異常
      相關(guān)文章
      亚洲精品456在线播放| 国产亚洲女在线线精品| 久久人午夜亚洲精品无码区| 亚洲精品国产V片在线观看 | 国产美女亚洲精品久久久综合| 亚洲视频无码高清在线| 亚洲手机中文字幕| 日日摸日日碰夜夜爽亚洲| 亚洲中文无码线在线观看| 亚洲日韩精品无码专区加勒比 | 亚洲AV噜噜一区二区三区| 亚洲精品天堂成人片?V在线播放| 亚洲色成人WWW永久在线观看| 爱情岛亚洲论坛在线观看| 亚洲欧洲精品久久| 亚洲人成电影在线天堂| 青草久久精品亚洲综合专区| 亚洲国模精品一区| 亚洲13又紧又嫩又水多| 亚洲日韩精品A∨片无码加勒比| 婷婷精品国产亚洲AV麻豆不片| 亚洲人成电影在线播放| 久久久久久亚洲av成人无码国产| 亚洲伊人久久精品| 国产亚洲精品岁国产微拍精品| 中文字幕乱码亚洲精品一区| 亚洲成A∨人片在线观看不卡| 亚洲综合图色40p| 亚洲Av综合色区无码专区桃色| 中文字幕亚洲第一| 色噜噜AV亚洲色一区二区| 亚洲国产成人VA在线观看| jlzzjlzz亚洲乱熟在线播放| 亚洲成AV人片在WWW| 国产成人无码综合亚洲日韩| 精品亚洲综合在线第一区| 精品亚洲永久免费精品| 国产精品亚洲w码日韩中文| 77777_亚洲午夜久久多人| 国产亚洲无线码一区二区| 亚洲一区二区三区在线|