gin框架对接快递100 查询快递跟踪记录 Golang实现快递查询
参考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实现快递查询的更多相关文章
- 对接京东jos遇到的坑 记录一下。方便查询
坑很多,有一些忘记了.文档乱的很,有问题可以私信我一下我看能不能想起来. 坑一.添加商品接口. {"error_response": {"code":" ...
- C#快递跟踪(基于快递100深度定制)
本文主要介绍快递跟踪的相关信息.如根据快递单号预测所属快递公司,判断快递是否已被签收,以及改良官方model后可在不用申请授权的情况下实现json,html,xml及text等多种格式以及单行多行,降 ...
- PHP最近做了物流快递查询的接口用得是快递100
最近做了物流快递查询的接口用得是快递100的,分享下心得体会 主要使用了2种接口,一个是api的 返回json xml 各种数据的 一个是返回的URL的 就是一个带结果的网址 . 1 申请 找一 ...
- 对接快递100&聚水潭API
对接快递100&聚水潭API 入我相思门,知我相思苦. 简介:对接第三方平台快递100&聚水潭API的简要总结. 1.感悟 个人感觉快递100的API更友好一些,比如有SDK可以调用: ...
- .netcore 写快递100的快递物流信息查询接口
快递100的物流信息查询接口,官方提供了一些demo;还好官方提供的代码是.netcore版本写的,不过写的有点low;根据官方提供的代码,我按照.netcore 的风格重构了代码:核心代码如下: / ...
- 快速上手微信小程序-快递100
2007 年 1 月 9 日,乔布斯在旧金山莫斯科尼会展中心发布了首款 iPhone,而在十年后的 1 月 9 日,微信小程序正式上线.张小龙以这样的形式,向乔布斯致敬. 小程序在哪里? 小程序功能模 ...
- java抓取快递100信息接口
package zeze; import java.io.IOException; import org.json.JSONArray; import org.json.JSONException; ...
- 快递100码json
{ "AOL澳通速递": "aolau", "A2U速递": "a2u", "AAE快递": &qu ...
- 在Asp.Net MVC中利用快递100接口实现订阅物流轨迹功能
前言 分享一篇关于在电商系统中同步物流轨迹到本地服务器的文章,当前方案使用了快递100做为数据来源接口,这个接口是收费的,不过提供的功能还是非常强大的,有专门的售后维护团队.也有免费的方案,类似于快递 ...
- php利用快递100接口获取物流信息
PHP使用CURL调用快递100接口查询运单信息 类代码如下: <?php/** * 快递100接口调用类 * @author 齐云海 * date: 2019/05/29 */ class E ...
随机推荐
- KingbaseES 控制文件损坏的恢复
sys_ control文件损坏: 需要手工指定一些参数完成sys_resetwal相关操作 当前数据库信息 test=# \d 关联列表 架构模式 | 名称 | 类型 | 拥有者 --------- ...
- 【Learning eBPF-1】什么是 eBPF?为什么它很吊?
本书中, eBPF 被称为一种 革命性的 内核技术,被广泛应用于网络.观测 和 安全工具中. 这种技术允许你在不重新编译内核的情况下,使能你的自定义工具,与内核数据进行交互.听起来很厉害. 1.1 追 ...
- Windows10基于Visual Studio 2019配置OpenCV4.X
下载OpenCV OpenCV官网 我们是Windows环境所以选择 Windows 配置环境变量 创建一个Visual Studio项目 配置Visual Studio属性 在包含目录中引入路径: ...
- 关于pwn题的栈平衡中ret的作用
以nssctf里的where_is_my_shell为例 题目提供了一个system函数,和一个buf数组.数组的栈空间如图所示,这里不讨论怎么解题,只说明payload里的ret的作用. 假设没有r ...
- 微服务集成Spring Cloud Zipkin实现链路追踪并集成Dubbo
1.什么是ZipKin Zipkin 是一个根据 Google 发表的论文" Dapper" 进行开源实现的分布式跟踪系统. Dapper是Google 公司内部的分布式追踪系统, ...
- 格式化字符串走过的坑 pwn109
格式化字符串走过的坑 pwn109 今天做的一道题有一个坑我调试半天终于打通了,格式化字符串的坑,确实不少,东西也比较多容易忘记,怎么说呢,功夫在平时,经验少了 老规矩先看一下保护 Full RELR ...
- Python生成测试数据--Faker的使用方法
# 官方文档:https://faker.readthedocs.io/en/master/index.html # 安装:pip install Faker from faker import Fa ...
- ODBC批量merge中出现主键冲突的分析
ODBC 批量 merge 中出现主键冲突的分析 一. 文档概括 客户某个 merge 语句运行时,发生主键冲突报错. 经分析,其原因如下: 由于 merge 语句中,ON 里的判断条件(谓词)中存在 ...
- opengauss-jdbc问题整理
opengauss-jdbc问题整理(更新中) 问题 1 jdbc 批量执行 insert 语句时返回结果不符合 Spring jpa 预期 问题描述: jdbc 执行查询时,可以使用prepares ...
- Java面试题总结:基础及语法篇169道
下载链接:https://gitee.com/ItBoShao/wechat_applet/blob/master/Java面试题总结:基础及语法篇169道.pdf