参考ui效果:

https://www.kuaidi100.com/?from=openv

gin框架:

请求地址 http://localhost:8822/kd100/auto_com_num?num=73119782411952

请求地址 http://localhost:8822/kd100/query_num_detail?num=73119782411952&comCode=zhongtong

//路由
router.GET("/kd100/auto_com_num", controller.AutoComNum) //获取快递公司类型
router.GET("/kd100/query_num_detail", controller.QueryNumDetail) //获取快递跟踪信息 //获取快递公司类型
func AutoComNum(ctx *gin.Context) {
//fmt.Println("AutoComNum...")
text := ctx.Query("num") //单号
url := "https://www.kuaidi100.com/autonumber/autoComNum?resultv2=1&text=" + text
paramData := gin.H{}
headerData := make(map[string]string, 1)
headerData["User-Agent"] = "Mozilla/5.0 (X11; Linux x86_64; rv:70.0) Gecko/20100101 Firefox/70.0"
resp := SendPostWithHeard(url, paramData, headerData)
type resAuto struct {
ComCode string `json:"comCode"`
LengthPre int `json:"lengthPre"`
NoCount int `json:"noCount"`
NoPre string `json:"noPre"`
Name string `json:"name"`
} type respData struct {
Num string `json:"num"`
ComCode string `json:"comCode"`
Auto []*resAuto `json:"auto"`
}
var resdata *respData
if err := json.Unmarshal([]byte(resp), &resdata); err != nil {
fmt.Println("Unmarshal resdata fail,", err)
httpext.Error(ctx, e.ERROR)
return
}
for _, v := range resdata.Auto {
kdName, ok := KD100Flags[v.ComCode]
if ok {
v.Name = kdName
} else {
v.Name = "未知快递"
}
}
httpext.SuccessExt(ctx, resdata)
} //获取快递跟踪信息
func QueryNumDetail(ctx *gin.Context) {
//fmt.Println("AutoComNum...")
num := ctx.Query("num") //单号
kdtype := ctx.Query("comCode") //快递类型 key := "XXXXXXXX" //客户授权key
customer := "XXXXXXXXXXXXXXXXXXXXXXX" //查询公司编号 posturl := "http://poll.kuaidi100.com/poll/query.do" //实时查询请求地址 paramData := make(map[string]string)
paramData["com"] = kdtype //快递公司编码
paramData["num"] = num //快递单号 paramDataSlice, _ := json.Marshal(paramData)
paramjson := string(paramDataSlice) sign := strings.ToUpper(crypto.GetMd5String(paramjson + key + customer))
fmt.Println("p=====>", customer) //POST请求需要三个参数,分别为customer(CustomerId)和sign(签名)和param(参数)
postRes, postErr := http.PostForm(posturl, url.Values{"customer": {customer}, "sign": {sign}, "param": {paramjson}})
if postErr != nil {
fmt.Println("查询失败" + postErr.Error())
httpext.ErrorExt(ctx, e.ERROR, "查询失败"+postErr.Error())
return
}
postBody, err := ioutil.ReadAll(postRes.Body)
if err != nil {
fmt.Println("查询失败,请至快递公司官网自行查询" + err.Error())
httpext.ErrorExt(ctx, e.ERROR, "查询失败,请至快递公司官网自行查询"+err.Error())
return
}
fmt.Println(string(postBody))
resp := make(map[string]interface{})
err = json.Unmarshal(postBody, &resp)
if err != nil {
fmt.Println("json.Unmarshal error", err.Error())
httpext.ErrorExt(ctx, e.ERROR, "查询失败,请至快递公司官网自行查询"+err.Error())
return
} httpext.SuccessExt(ctx, resp)
} // SendPostWithHeard ... 发送POST请求 ...
// url: 请求地址
// data: POST请求提交的数据
// hearderParam 设置header头信息
// contentType: 请求体格式,如:json
// content: 请求放回的内容
//func SendPostWithHeard(url string, data interface{}, hearderParam map[string]string, contentType string) string {
func SendPostWithHeard(url string, data interface{}, hearderParam map[string]string) string {
bytesData, err := json.Marshal(data)
if err != nil {
fmt.Println(err.Error())
return err.Error()
} reader := bytes.NewReader(bytesData)
request, err := http.NewRequest("POST", url, reader)
if err != nil {
fmt.Println(err.Error())
return err.Error()
}
//增加header选项 添加请求头
if len(hearderParam) > 0 {
for k, v := range hearderParam {
request.Header.Set(k, v)
}
}
//request.Header.Set("Content-Type", contentTypeParam[contentType]) client := http.Client{}
resp, err := client.Do(request)
if err != nil {
fmt.Println(err.Error())
return err.Error()
}
respBytes, err := ioutil.ReadAll(resp.Body)
fmt.Println(1111111)
fmt.Println(respBytes)
if err != nil {
fmt.Println(err.Error())
return err.Error()
} return string(respBytes)
} var KD100Flags = map[string]string{
"ane66": "安能快递",
"debangwuliu": "德邦物流",
"debangkuaidi": "德邦快递",
"ems": "EMS",
"guotongkuaidi": "国通快递",
"huitongkuaidi": "百世快递",
"jd": "京东物流",
"kuayue": "跨越速运",
"pjbest": "品骏快递",
"shentong": "申通快递",
"shunfeng": "顺丰速运",
"suer": "速尔快递",
"xinfengwuliu": "信丰物流",
"youshuwuliu": "优速物流",
"youzhengguonei": "邮政快递包裹",
"yuantong": "圆通速递",
"yuantongguoji": "圆通国际",
"yunda": "韵达快递",
"zhaijisong": "宅急送",
"zhongtong": "中通快递",
"ewe": "EWE全球快递",
"quanyikuaidi": "全一快递",
"tiantian": "天天快递",
"sxjdfreight": "顺心捷达",
"dhl": "DHL-中国件",
"tnt": "TNT",
"other": "其它快递",
}

获取快递公司类型 返回参:

    {
"data": {
"num": "1009414746833",
"comCode": "",
"auto": [
{
"comCode": "ems",
"lengthPre": 13,
"noCount": 32,
"noPre": "100941",
"name": "EMS"
},
{
"comCode": "youzhengguonei",
"lengthPre": 13,
"noCount": 1,
"noPre": "100941",
"name": "邮政快递包裹"
}
]
},
"errmsg": "ok",
"errno": 200
}

获取快递跟踪信息 反参

    {
"data": {
"com": "zhongtong",
"condition": "00",
"data": [
{
"context": "订单已由【菜鸟驿站】代收,感谢您在京东购物,欢迎您再次光临!",
"ftime": "2020-04-05 11:47:12",
"location": "",
"time": "2020-04-05 11:47:12"
},
{
"context": "配送员开始配送,请您准备收货,配送员,方辉,手机号,15807710153",
"ftime": "2020-04-05 08:15:18",
"location": "",
"time": "2020-04-05 08:15:18"
},
{
"context": "货物已分配,等待配送",
"ftime": "2020-04-05 07:48:13",
"location": "",
"time": "2020-04-05 07:48:13"
},
{
"context": "货物已到达【南宁良庆营业部】",
"ftime": "2020-04-05 07:48:12",
"location": "",
"time": "2020-04-05 07:48:12"
},
{
"context": "货物已完成分拣,离开【南宁分拨中心】",
"ftime": "2020-04-04 23:50:33",
"location": "",
"time": "2020-04-04 23:50:33"
},
{
"context": "货物已完成分拣,离开【南宁分拨中心】",
"ftime": "2020-04-04 21:46:25",
"location": "",
"time": "2020-04-04 21:46:25"
},
{
"context": "货物已到达【南宁分拨中心】",
"ftime": "2020-04-04 21:44:52",
"location": "",
"time": "2020-04-04 21:44:52"
},
{
"context": "货物已完成分拣,离开【南宁分拨中心】",
"ftime": "2020-04-04 18:51:02",
"location": "",
"time": "2020-04-04 18:51:02"
},
{
"context": "货物已交付京东物流",
"ftime": "2020-04-04 17:47:17",
"location": "",
"time": "2020-04-04 17:47:17"
}
],
"ischeck": "0",
"message": "ok",
"nu": "73119782411952",
"state": "0",
"status": "200"
},
"errmsg": "ok",
"errno": 200
}

gin框架对接快递100 查询快递跟踪记录 Golang实现快递查询的更多相关文章

  1. 对接京东jos遇到的坑 记录一下。方便查询

    坑很多,有一些忘记了.文档乱的很,有问题可以私信我一下我看能不能想起来. 坑一.添加商品接口. {"error_response": {"code":" ...

  2. C#快递跟踪(基于快递100深度定制)

    本文主要介绍快递跟踪的相关信息.如根据快递单号预测所属快递公司,判断快递是否已被签收,以及改良官方model后可在不用申请授权的情况下实现json,html,xml及text等多种格式以及单行多行,降 ...

  3. PHP最近做了物流快递查询的接口用得是快递100

    最近做了物流快递查询的接口用得是快递100的,分享下心得体会 主要使用了2种接口,一个是api的 返回json xml 各种数据的 一个是返回的URL的  就是一个带结果的网址  . 1  申请 找一 ...

  4. 对接快递100&聚水潭API

    对接快递100&聚水潭API 入我相思门,知我相思苦. 简介:对接第三方平台快递100&聚水潭API的简要总结. 1.感悟 个人感觉快递100的API更友好一些,比如有SDK可以调用: ...

  5. .netcore 写快递100的快递物流信息查询接口

    快递100的物流信息查询接口,官方提供了一些demo;还好官方提供的代码是.netcore版本写的,不过写的有点low;根据官方提供的代码,我按照.netcore 的风格重构了代码:核心代码如下: / ...

  6. 快速上手微信小程序-快递100

    2007 年 1 月 9 日,乔布斯在旧金山莫斯科尼会展中心发布了首款 iPhone,而在十年后的 1 月 9 日,微信小程序正式上线.张小龙以这样的形式,向乔布斯致敬. 小程序在哪里? 小程序功能模 ...

  7. java抓取快递100信息接口

    package zeze; import java.io.IOException; import org.json.JSONArray; import org.json.JSONException; ...

  8. 快递100码json

    { "AOL澳通速递": "aolau", "A2U速递": "a2u", "AAE快递": &qu ...

  9. 在Asp.Net MVC中利用快递100接口实现订阅物流轨迹功能

    前言 分享一篇关于在电商系统中同步物流轨迹到本地服务器的文章,当前方案使用了快递100做为数据来源接口,这个接口是收费的,不过提供的功能还是非常强大的,有专门的售后维护团队.也有免费的方案,类似于快递 ...

  10. php利用快递100接口获取物流信息

    PHP使用CURL调用快递100接口查询运单信息 类代码如下: <?php/** * 快递100接口调用类 * @author 齐云海 * date: 2019/05/29 */ class E ...

随机推荐

  1. 实现一个简单的echarts柱状图PythonFlask

    bar.html 1 <!DOCTYPE html> 2 <html style="height: 100%"> 3 <head> 4 < ...

  2. LiftPool:双向池化操作,细节拉满,再也不怕丢特征了 | ICLR 2021

    论文参考信号处理中提升方案提出双向池化操作LiftPool,不仅下采样时能保留尽可能多的细节,上采样时也能恢复更多的细节.从实验结果来看,LiftPool对图像分类能的准确率和鲁棒性都有不错的提升,而 ...

  3. #树的直径#洛谷 3174 [HAOI2009]毛毛虫

    题目 分析 类似于树的直径,只是点权变成了出度-1, 注意减1之后会漏掉两个端点要加回去,当\(n=1\)时特判 代码 #include <cstdio> #include <cct ...

  4. #线段树、树状数组#D 筹备计划

    分析 首先这个位置应该是带权中位数\((\geq \frac{sum+1}{2}(奇数要加一,WA了几次了))\),但是既然有这个选择的限制, 那么要用线段树求出可选择的前驱和后继,然后用树状数组计算 ...

  5. 使用OHOS SDK构建mimalloc

    参照OHOS IDE和SDK的安装方法配置好开发环境. 从github下载源码. 执行如下命令: git clone https://github.com/microsoft/mimalloc.git ...

  6. C++获取appdata路径

    C++获取appdata路径的方式:    SHGetSpecialFolderPath wchar_t buffer[MAX_PATH]; SHGetSpecialFolderPath(0, buf ...

  7. Graph Embedding-DeepWalk

    一言以蔽之,DeepWalk是在graph上,通过随机游走来产生一段定长的结点序列,并将其通过word2vec的方式获得各个结点的embedding的算法. DeepWalk一共涉及以下几个内容: 随 ...

  8. 安装CentOS-6.3-i386-minimal

    服务器开发者都离不开linux,这里一步步讲下linux安装和开发环境部署 一.下载安装镜像文件 这里以安装CentOS-6.3-i386-minimal为例,这个自带安装软件最少,简单而小巧,偏于你 ...

  9. MMDeploy部署实战系列【第五章】:Windows下Release x64编译mmdeploy(C++),对TensorRT模型进行推理

    MMDeploy部署实战系列[第五章]:Windows下Release x64编译mmdeploy(C++),对TensorRT模型进行推理 这个系列是一个随笔,是我走过的一些路,有些地方可能不太完善 ...

  10. JS中通过url动态获取图片大小的方法小结(两种方法)

    很多时候再项目中,我们往往需要先获取图片的大小再加载图片,但是某些特定场景,如用过cocos2d-js的人都知道,在它那里只能按比例缩放大小,是无法设置指定大小的图片的,这就是cocos2d-js 的 ...