快递鸟是全球最大的第三方快递物流接口服务商, 目前已经集成了600家快递单号查询接口,31家电子面单接口。高实时、高稳定、高并发,支持快递单号自动识别。
快递鸟第三方快递查询接口很好用,使用的用户很多(有十几个千人技术QQ群),大的ERP基本都用的是快递鸟的接口,非淘系的电商平台也都是用快递鸟提供的接口服务。整个对接非常简单,到快递鸟网站免费注册申请KEY和ID,下载调用的demo,修改下参数对接后就可以了。 有免费版和针对性收费版的,根据自己需要可以选择相应的服务套餐
技术文档请参考快递鸟官网api:https://www.kdniao.com/api-track
快递公司编码链接:https://www.kdniao.com/file/2020快递鸟接口支持快递公司编码.xlsx
(一)接入流程:
1>.注册快递鸟账号,
API_ID:XXXXXX
API_KEY:XXXXXXXXXXXXXXXXXX
2>.服务申请
在个人中心里面申请需要的服务,即时查询功能有免费的服务
3>.对接服务
写自己的业务逻辑----本文主体
4>.测试代码
5>.正式使用
请求demo案例:快递鸟官网有多种demo语言可供选择,以java为例
请求示例:
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.OutputStreamWriter; import java.io.UnsupportedEncodingException; import java.net.HttpURLConnection; import java.net.URL; import java.net.URLEncoder; import java.util.HashMap; import java.util.Map; import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; import java.security.MessageDigest;
/**
* @技术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格式
* 应用级参数
* 请求示例
* ZTO请求示例:
* { * "OrderCode": "", * "ShipperCode": "ZTO", * "LogisticCode": "638650888018", * } * * JD请求示例: * { * "OrderCode": "", * "CustomerName": "", * "ShipperCode": "JD", * "LogisticCode": "JDVA00003618100", * } * * SF请求示例: * { * "OrderCode": "", * "CustomerName": "1234", * "ShipperCode": "SF", * "LogisticCode": "SF00003618100", * } */public class KdApiSearchDemo { //用户ID,快递鸟提供,注意保管,不要泄漏 private String EBusinessID="1237100";//即用户ID,登录快递鸟官网会员中心获取 https://www.kdniao.com/UserCenter/v4/UserHome.aspx //API key,快递鸟提供,注意保管,不要泄漏 private String ApiKey="56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17";//即API key,登录快递鸟官网会员中心获取 https://www.kdniao.com/UserCenter/v4/UserHome.aspx //请求url, 正式环境地址 private String ReqURL="https://api.kdniao.com/Ebusiness/EbusinessOrderHandle.aspx"; public static void main(String[] args) { try { KdApiSearchDemo api = new KdApiSearchDemo(); System.out.println(api.orderOnlineByJson()); } catch (Exception e) { e.printStackTrace(); } } //即时查询接口 public String orderOnlineByJson() throws Exception{ // 组装应用级参数 String RequestData= "{"+ "'CustomerName': '',"+ "'OrderCode': '',"+ "'ShipperCode': 'YTO',"+ "'LogisticCode': 'YT00003618100',"+ "}"; // 组装系统级参数 Map params = new HashMap(); params.put("RequestData", urlEncoder(RequestData, "UTF-8")); params.put("EBusinessID", EBusinessID); params.put("RequestType", "1002");//免费即时查询接口指令1002/在途监控即时查询接口指令8001/地图版即时查询接口指令8003 String dataSign=encrypt(RequestData, ApiKey, "UTF-8"); params.put("DataSign", urlEncoder(dataSign, "UTF-8")); params.put("DataType", "2"); // 以form表单形式提交post请求,post请求体中包含了应用级参数和系统级参数 String result=sendPost(ReqURL, params); //根据公司业务处理返回的信息...... return result; } /** * MD5加密 * str 内容 * charset 编码方式 * @throws Exception */ @SuppressWarnings("unused") private String MD5(String str,String charset) throws Exception { MessageDigest md = MessageDigest.getInstance("MD5"); md.update(str.getBytes(charset)); byte[] result = md.digest(); StringBuffer sb = new StringBuffer(32); for (int i = 0; i < result.length; i++) { int val = result[i] & 0xff; if (val <= 0xf) { sb.append("0"); } sb.append(Integer.toHexString(val)); } return sb.toString().toLowerCase(); } /** * base64编码 * str 内容 * charset 编码方式 * @throws UnsupportedEncodingException */ private String base64(String str, String charset) throws UnsupportedEncodingException{ String encoded = Base64.encode(str.getBytes(charset)); return encoded; } @SuppressWarnings("unused") private String urlEncoder(String str, String charset) throws UnsupportedEncodingException{ String result = URLEncoder.encode(str, charset); return result; } /** * 电商Sign签名生成 * content 内容 * keyValue ApiKey * charset 编码方式 * @throws UnsupportedEncodingException ,Exception * @return DataSign签名 */ @SuppressWarnings("unused") private String encrypt (String content,String keyValue,String charset) throws UnsupportedEncodingException, Exception { if (keyValue != null) { return base64(MD5(content + keyValue, charset), charset); } return base64(MD5(content, charset), charset); } /** * 向指定 URL 发送POST方法的请求 * url 发送请求的 URL * params 请求的参数集合 * @return 远程资源的响应结果 */ @SuppressWarnings("unused") private String sendPost(String url, Map params) { OutputStreamWriter out = null; BufferedReader in = null; StringBuilder result = new StringBuilder(); try { URL realUrl = new URL(url); HttpURLConnection conn =(HttpURLConnection) realUrl.openConnection(); // 发送POST请求必须设置如下两行 conn.setDoOutput(true); conn.setDoInput(true); // POST方法 conn.setRequestMethod("POST"); // 设置通用的请求属性 conn.setRequestProperty("accept", "*/*"); conn.setRequestProperty("connection", "Keep-Alive"); conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)"); conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); conn.connect(); // 获取URLConnection对象对应的输出流 out = new OutputStreamWriter(conn.getOutputStream(), "UTF-8"); // 发送请求参数 if (params != null) { StringBuilder param = new StringBuilder(); for (Map.Entry< String, String> entry : params.entrySet()) { if(param.length()>0){ param.append("&"); } param.append(entry.getKey()); param.append("="); param.append(entry.getValue()); System.out.println(entry.getKey()+":"+entry.getValue()); } System.out.println("param:"+param.toString()); out.write(param.toString()); } // flush输出流的缓冲 out.flush(); // 定义BufferedReader输入流来读取URL的响应 in = new BufferedReader( new InputStreamReader(conn.getInputStream(), "UTF-8")); String line; while ((line = in.readLine()) != null) { result.append(line); } } catch (Exception e) { e.printStackTrace(); } //使用finally块来关闭输出流、输入流 finally{ try{ if(out!=null){ out.close(); } if(in!=null){ in.close(); } } catch(IOException ex){ ex.printStackTrace(); } } return result.toString(); }}1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.45.46.47.48.49.50.51.52.53.54.55.56.57.58.59.60.61.62.63.64.65.66.67.68.69.70.71.72.73.74.75.76.77.78.79.80.81.82.83.84.85.86.87.88.89.90.91.92.93.94.95.96.97.98.99.100.101.102.103.104.105.106.107.108.109.110.111.112.113.114.115.116.117.118.119.120.121.122.123.124.125.126.127.128.129.130.131.132.133.134.135.136.137.138.139.140.141.142.143.144.145.146.147.148.149.150.151.152.153.154.155.156.157.158.159.160.161.162.163.164.165.166.167.168.169.170.171.172.173.174.175.176.177.178.179.180.181.182.183.184.