快递鸟API单号查询接口功能之python

简介: 之前写快递的时候,官网上只有php和.net的示例,而我使用python封装的相关功能踩了许多坑,才搞出来,分享一下我的方法。先上图,看结果:技术文档请参考快递鸟官网api:免费查询快递接口_100%安全保障_物流即时查询API-快递鸟快递公司编码链接:https://www.

之前写快递的时候,官网上只有php和.net的示例,而我使用python封装的相关功能踩了许多坑,才搞出来,分享一下我的方法。
先上图,看结果:

技术文档请参考快递鸟官网api:免费查询快递接口_100%安全保障_物流即时查询API-快递鸟

快递公司编码链接:https://www.kdniao.com/file/2019快递鸟接口支持快递公司编码.xlsx

(一)接入流程:

1>.注册快递鸟账号,

API_ID:test1234567
API_KEY:XXXXXXXXXXXXXXXXXX

2>.服务申请

在个人中心里面申请需要的服务,即时查询功能有免费的服务

3>.对接服务

***写自己的业务逻辑***----本文主体

4>.测试代码
5>.正式使用
1、登录快递鸟官网注册页面注册快递鸟账号

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

2、登录快递鸟用户管理后台

网址:用户登录_快递鸟API让物流接口对接更简单

注:登录快递鸟用户管理后台后获得用户ID和APIKey,此用于保证应用来源的可靠性,避免应用伪造,被不法使用。

3、进入“我的会员中心”进行实名认证

注:

3.1、认证类型、应用类型根据用户实际情况选择即可,接口返回数据与选择结果无关;

3.2、标记为*的为必填,要求上传清晰、jpg格式且小于2M的证件图片;

3.3、技术对接人信息为用户方对接工程师的信息;

3.4、如有其他疑问可进入官网加入商务合作群进行咨询。

认证成功后,进入“产品服务管理”,开通相关会员服务

注:

物流查询(免费版)会员套餐为免费版,有效期1年结束后,如在近3个月内有数据交互系统会自动免费续期;

(二)、接口描述/说明

(1)查询接口支持按照运单号查询(单个查询)。

(2)接口需要指定快递单号的快递公司编码,格式不对或则编码错误都会返失败的信息。

如:EMS物流单号应选择快递公司编码(EMS)查看快递公司编码

(3)返回的物流跟踪信息按照发生的时间升序排列。

(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

(三)必传参数说明:

请求内容:

OrderCode:订单编号—非必须

ShipperCode:快递公司编码—必须

LogisticCode:物流单号—必须

系统参数

RequestData:将JSON格式请求内容进行URL(utf-8)编码;

EBusinessID:API_ID;

RequestType:1002;

DataSign:请求内容(未编码)+AppKey)进行MD5加密,然后Base64编码,最后 进行URL(utf-8)编码

(四)功能封装

请求数据处理

def organize_request_data(shipper_code, logistic_code):

"""编码请求数据"""
original_request_data = {
    "OrderCode": "",  # 默认设置为空
    "ShipperCode": shipper_code,
    "LogisticCode": logistic_code,
    "IsHandleInfo": "0"
}
# 数据转换为json格式
data = json.dumps(original_request_data)

# 进行url编码
# 这里有个坑,有兴趣的可以试试
#  request_data = quote(data),二者还是有区别的
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

# 请求内容(未编码) + AppKey
# 此处有另一个坑,关于MD5加密,字典中存不存在空格,结果并不一样,而对于此接口,需要去除空格
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

/MD5的空格效果 /

(五)视图逻辑:

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,此处需处理取得的数据,以取得所需的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"
    }
    # 按要求设置请求头信息
    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)

另外,python有快递鸟的第三方包,但是有些地方需要修改,而且看的有点晕,就自己写了一个用用,感觉更明白。若有不当之处,敬请斧正。

目录
相关文章
|
15天前
|
缓存 前端开发 API
API接口封装系列
API(Application Programming Interface)接口封装是将系统内部的功能封装成可复用的程序接口并向外部提供,以便其他系统调用和使用这些功能,通过这种方式实现系统之间的通信和协作。下面将介绍API接口封装的一些关键步骤和注意事项。
|
22天前
|
监控 前端开发 JavaScript
实战篇:商品API接口在跨平台销售中的有效运用与案例解析
随着电子商务的蓬勃发展,企业为了扩大市场覆盖面,经常需要在多个在线平台上展示和销售产品。然而,手工管理多个平台的库存、价格、商品描述等信息既耗时又容易出错。商品API接口在这一背景下显得尤为重要,它能够帮助企业在不同的销售平台之间实现商品信息的高效同步和管理。本文将通过具体的淘宝API接口使用案例,展示如何在跨平台销售中有效利用商品API接口,以及如何通过代码实现数据的统一管理。
|
1月前
|
安全 算法 API
产品经理必备知识——API接口
前言 在古代,我们的传输信息的方式有很多,比如写信、飞鸽传书,以及在战争中使用的烽烟,才有了著名的烽火戏诸侯,但这些方式传输信息的效率终究还是无法满足高速发展的社会需要。如今万物互联的时代,我通过一部手机就可以实现衣食住行的方方面面,比如:在家购物、远程控制家电、自动驾驶等等,背后都离不开我们今天要聊的API接口。
|
1月前
|
数据采集 JSON API
如何实现高效率超简洁的实时数据采集?——Python实战电商数据采集API接口
你是否曾为获取重要数据而感到困扰?是否因为数据封锁而无法获取所需信息?是否因为数据格式混乱而头疼?现在,所有这些问题都可以迎刃而解。让我为大家介绍一款强大的数据采集API接口。
|
1月前
|
机器学习/深度学习 数据可视化 数据处理
Python数据可视化:探索Matplotlib库的强大功能
本文将深入探讨Python中用于数据可视化的重要工具之一——Matplotlib库。通过介绍Matplotlib库的基本概念、常用功能和实际应用案例,帮助读者更好地了解如何利用Matplotlib创建各种吸引人的数据图表。
|
2天前
|
Java API Android开发
[NDK/JNI系列04] JNI接口方法表、基础API与异常API
[NDK/JNI系列04] JNI接口方法表、基础API与异常API
11 0
|
5天前
|
XML JSON API
快速淘宝商品详情页面API接口传输 php
PI(Application Programming Interface,应用程序接口)是一组预定义的函数、协议和工具,用于构建软件应用程序之间的交互。它允许不同的软件系统和应用通过统一的接口进行数据交换和通信
|
7天前
|
Python
基于Django的Python应用—学习笔记—功能完善
基于Django的Python应用—学习笔记—功能完善
|
9天前
|
人工智能 API 开发者
免费使用Kimi的API接口,kimi-free-api真香
今年AI应用兴起,各类智能体涌现,但API免费额度有限。为解决这一问题,GitHub上的[kimi-free-api](https://github.com/LLM-Red-Team/kimi-free-api)项目提供了方便,支持高速流式输出、多轮对话等,与ChatGPT接口兼容。此外,还有其他大模型的免费API转换项目,如跃问StepChat、阿里通义Qwen等。该项目可帮助用户免费体验,通过Docker-compose轻松部署。只需获取refresh_token,即可开始使用。这个开源项目促进了AI学习和开发,为探索AI潜力提供了新途径。
215 2
|
11天前
|
计算机视觉 Python
如何利用Python实现简单的图像处理功能
本文介绍了如何使用Python编程语言和相关库实现简单的图像处理功能。通过学习本文,读者将了解如何读取图像文件、调整图像大小、修改图像亮度和对比度、应用滤镜效果以及保存处理后的图像。这些技术将帮助读者快速入门图像处理领域,并为他们进一步探索更高级的图像处理技术打下基础。

热门文章

最新文章