135 lines
4.1 KiB
Go
135 lines
4.1 KiB
Go
package kdapisearch
|
||
|
||
import (
|
||
"crypto/md5"
|
||
"encoding/base64"
|
||
"fmt"
|
||
"io"
|
||
"io/ioutil"
|
||
"net/http"
|
||
"strings"
|
||
)
|
||
|
||
/**
|
||
* @技术QQ群: 可登录官网https://www.kdniao.com/右侧查看技术群号
|
||
* @see: https://kdniao.com/api-track
|
||
* @copyright: 深圳市快金数据技术服务有限公司
|
||
* ID和Key请到官网申请:https://kdniao.com/reg
|
||
|
||
|
||
|
||
* 即时查询接口
|
||
* 此接口用于向快递公司实时查询物流轨迹信息。该功能支持情况需查看技术文档。
|
||
* 正式地址:https://api.kdniao.com/Ebusiness/EbusinessOrderHandle.aspx
|
||
*
|
||
*
|
||
* 系统级参数
|
||
* RequestData String R 请求内容为JSON格式 详情可参考接口技术文档:https://www.kdniao.com/documents
|
||
* EBusinessID String R 用户ID
|
||
* RequestType String R 请求接口指令
|
||
* DataSign String R 数据内容签名,加密方法为:把(请求内容(未编码)+ApiKey)进行MD5加密--32位小写,然后Base64编码,最后进行URL(utf-8)编码
|
||
* DataType String R DataType=2,请求、返回数据类型均为JSON格式
|
||
|
||
|
||
* 应用级参数
|
||
* R-必填(Required),O-可选(Optional),C-报文中该参数在一定条件下可选(Conditional)
|
||
* OrderCode String(30) O 订单编号
|
||
* ShipperCode String(10) R 快递公司编码 详细编码参考《快递鸟接口支持快递公司编码.xlsx》 https://www.kdniao.com/documents
|
||
* LogisticCode String(30) R 快递单号
|
||
* CustomerName String(50) C ShipperCode为SF时必填,对应寄件人/收件人手机号后四位;ShipperCode为其他快递时,可不填或保留字段,不可传值
|
||
|
||
* 请求示例
|
||
* ZTO请求示例:
|
||
* {
|
||
* "OrderCode": "",
|
||
* "ShipperCode": "ZTO",
|
||
* "LogisticCode": "638650888018",
|
||
* }
|
||
*
|
||
* JD请求示例:
|
||
* {
|
||
* "OrderCode": "",
|
||
* "CustomerName": "",
|
||
* "ShipperCode": "JD",
|
||
* "LogisticCode": "JDVA00003618100",
|
||
* }
|
||
*
|
||
* SF请求示例:
|
||
* {
|
||
* "OrderCode": "",
|
||
* "CustomerName": "1234",
|
||
* "ShipperCode": "SF",
|
||
* "LogisticCode": "SF00003618100",
|
||
* }
|
||
*/
|
||
|
||
// 请求url --正式地址
|
||
const Url string = "https://api.kdniao.com/Ebusiness/EbusinessOrderHandle.aspx"
|
||
|
||
// 用户ID,快递鸟提供,注意保管,不要泄漏
|
||
const EBusinessID string = "1237100" //即用户ID,登录快递鸟官网会员中心获取 https://www.kdniao.com/UserCenter/v4/UserHome.aspx
|
||
// API key,快递鸟提供,注意保管,不要泄漏
|
||
const ApiKey string = "56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17" //即API key,登录快递鸟官网会员中心获取 https://www.kdniao.com/UserCenter/v4/UserHome.aspx
|
||
|
||
func main() {
|
||
getResult()
|
||
}
|
||
|
||
func getResult() {
|
||
//以form表单形式提交post请求,post请求体中包含了应用级参数和系统级参数
|
||
result := post(Url, getParams())
|
||
fmt.Println(result)
|
||
} //输出结果
|
||
|
||
func getParams() (v map[string]string) {
|
||
//请求接口指令
|
||
const RequestType string = "1002" //免费即时查询接口指令1002/在途监控即时查询接口指令8001/地图版即时查询接口指令8003
|
||
// 组装应用级参数
|
||
const RequestData string = "{" +
|
||
"'CustomerName': ''," +
|
||
"'OrderCode': ''," +
|
||
"'ShipperCode': 'YTO'," +
|
||
"'LogisticCode': 'YT00003618100'," +
|
||
"}"
|
||
var DataSign string = getSign(RequestData)
|
||
// 组装系统级参数
|
||
v = map[string]string{
|
||
"RequestType": RequestType,
|
||
"EBusinessID": EBusinessID,
|
||
"DataType": "2",
|
||
"RequestData": RequestData,
|
||
"DataSign": DataSign,
|
||
}
|
||
return v
|
||
}
|
||
|
||
func base64Encode(src []byte) []byte {
|
||
return []byte(base64.StdEncoding.EncodeToString(src))
|
||
}
|
||
|
||
func getSign(n string) (data string) {
|
||
str := n + ApiKey
|
||
w := md5.New()
|
||
io.WriteString(w, str)
|
||
md5str := fmt.Sprintf("%x", w.Sum(nil))
|
||
debyte := base64Encode([]byte(md5str))
|
||
data = fmt.Sprintf("%s", debyte)
|
||
return data
|
||
} //签名
|
||
|
||
func post(url string, params map[string]string) string {
|
||
var values []string
|
||
for k, v := range params {
|
||
values = append(values, fmt.Sprintf("%s=%s", k, v))
|
||
}
|
||
resp, err := http.Post(url, "application/x-www-form-urlencoded", strings.NewReader(strings.Join(values, "&")))
|
||
if err != nil || resp.StatusCode != 200 {
|
||
fmt.Println(err.Error())
|
||
}
|
||
contentBytes, err := ioutil.ReadAll(resp.Body)
|
||
if err != nil {
|
||
fmt.Println(err.Error())
|
||
}
|
||
return string(contentBytes)
|
||
}
|