




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、免费顺丰快递接口api对接调用demo接口地址:http:/api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx支持格式:json 请求方式:HTTP POST接口平台:快递鸟免费查询接口 请求方法的编码格式(utf-8):"application/x-www-form-urlencoded;charset=utf-8"。顺丰快递接口api申请JSON请求/返回示例:1.请求 "OrderCode": "&q
2、uot;, "ShipperCode": "SF", "LogisticCode": "118650888018"2.返回没有物流轨迹的 "EBusinessID": "1109259", "Traces": , "OrderCode": "&q
3、uot;, "ShipperCode": "SF", "LogisticCode": "118461988807", "Success": false, "Reason": null有物流轨迹的 "EBusinessID": "1109259", "OrderCode": "", "ShipperCode": "SF", "LogisticCode
4、": "118461988807", "Success": true, "State": 3, "Reason": null, "Traces": "AcceptTime": "2014/06/25 08:05:37", "AcceptStation": "正在派件.(派件人:邓裕富,电话深圳 市", "Remark": null , "AcceptT
5、ime": "2014/06/25 04:01:28", "AcceptStation": "快件在 深圳集散中心 ,准备送往下一站 深圳 深圳市", "Remark": null , "AcceptTime": "2014/06/25 01:41:06", "AcceptStation": "快件在 深圳集散中心 深圳市", "Remark": null , "AcceptTime":
6、 "2014/06/24 20:18:58", "AcceptStation": "已收件深圳市", "Remark": null , "AcceptTime": "2014/06/24 20:55:28", "AcceptStation": "快件在 深圳 ,准备送往下一站 深圳集散中心 深圳市", "Remark": null , "AcceptTime": "2014/06/25
7、10:23:03", "AcceptStation": "派件已签收深圳市", "Remark": null , "AcceptTime": "2014/06/25 10:23:03", "AcceptStation": "签收人是:已签收深圳市", "Remark": null 注:接口及签名说明1)、支持http传输协议2)、支持的数据传输格式 Json/Xml(暂不支持<content/>这种形式)。 编码格
8、式:UTF-8 交互协议上统一用UTF-8,避免传递中文数据出现乱码。3)、接入步骤 注册成为用户(注:注册成功选择服务立即使用,无需审批)。注册成功后,登录就可以查看ID和key。 注册方式通过网络平台:按照接口官网提示进行注册申请,注册成功并且登录,将得到一组电商ID和AppKey。电商ID是调用接口服务的身份证明,不可更改、不可转用,AppKey是应用访问API的签名附加密钥,必须妥善保存。两者关系类似于登录帐号和密码,两者都会在签名和业务参数中使用。注册成功登录之后认证:即可申请接口 申请后ID和KEY自动激活(1) 开发服务开发自身业务的服务,服务需按照后面接口的定义规则。(2) 查
9、看接口调用的DEMO物流技术接口提供调用物流接口的DEMO(.Net版本),包括网上在线订单下单、物流轨迹查询等物流行业标准化的下单操作流程与数据查询格式。提交接入处理的相关代码如有不明白的地方可与物流技术接口人协作开发。DEMO下载地址: 4)、接口数据包结构图例 - 数据包结构 (系统级数据)5)、XML范例/JSON 范例 string userID = "1109259" string keyValue = "56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17"/加密私钥,由发货通提供 string url = "
10、http:/api.kdniao.cc:8081/Ebusiness/EbusinessOrderHandle.aspx" /请求地址 string DataType = "1" /1-xml;2-json string charset="UTF-8"/字符编码采用UTF-8 string xmlStr = "<Content><OrderCode></OrderCode><ShipperCode>SF</ShipperCode><LogisticCode>118
11、650888088</LogisticCode></Content>"/ XML字符串 string xmlStr = ""OrderCode":"","ShipperCode":"SF","LogisticCode":"118461988807"" / JSON字符串string datasign = MD5(xmlStr+keyValue, "UTF-8");/生成加密签名加密通过对参数xmlStr
12、+ keyValue得到加密后的字符串string PostStr = "RequestType=1002&EBusinessID= userID &RequestData=xmlStr &DataSign= datasign&DataType=DataType" /请求报文参数string post = this.DoPost(url, PostStr);/ 通讯协议使用Http协议Post请求方式6)、流程示意图7)、网关地址测试接口:http:/api.kdniao.cc:8081/Ebusiness/EbusinessOrderHan
13、dle.aspx测试电商ID=1237100,AppKey=518a73d8-1f7f-441a-b644-33e77b49d846正式接口:http:/api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx注意:正式(自行注册)环境下使用时,需提供请求的IP给接口登记8)、关于签名接口和第三方电子商务公司系统进行对接,有一定的安全机制。采用IP认证加签名的方式对接,具体方案如下:(1) 防止数据被篡改在POST请求中会传递5个参数4个必须参数:RequestType=请求指令类型EBusinessID=电商IDRequestData=数据内容(UR
14、L编码:UTF-8)DataSign= 签名摘要(URL编码:UTF-8(base64(MD5(数据内容 +AppKey)1个可选参数:DataType=返回数据类型(1-xml,2-json;默认为2格式)注:DataSign生成后,对方接收到数据后,以同样的算法进行签名,生成摘要,对比两者的摘要是否相同,如果不同,说明传递过程中发生数据篡改,对接过程中如有不明白之处可双方技术协作进行(2) 调用接口的身份认证注册成为接口用户后,会生成对应的电商ID和AppKey,电商ID相当于用户名,AppKey相当于密码。注:请勿遗漏或传递可能递增大接口调用维护举例说明:(a) 假设RequestDat
15、a (XML)内容为: <Content><ShipperCode>SF</ShipperCode><LogisticCode>118954907573</LogisticCode></Content>,经过URL(UTF-8)编码的内容为%3cContent%3e%3cShipperCode%3eSF%3c%2fShipperCode%3e%3cLogisticCode%3e118954907573%3c%2fLogisticCode%3e%3c%2fContent%3e, EBusinessID为1109259,App
16、Key为56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17(b) 那么DataSign签名的内容为<Content><ShipperCode>SF</ShipperCode><LogisticCode>118954907573</LogisticCode></Content>56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17,经过md5和base64后的内容就为YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE=,在经过URL(UTF-8)编码
17、的内容为YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE%3d(c) 最终要发送的数据为RequestType=1002&EBusinessID=1109259&RequestData =%3cContent%3e%3cShipperCode%3eSF%3c%2fShipperCode%3e%3cLogisticCode%3e118954907573%3c%2fLogisticCode%3e%3c%2fContent%3e &DataSign = YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE
18、%3d& DataType=2(d) 接收方收到数据后,获得EBusinessID 和RequestData和DataSign等这几个数据。(e) 接收方对EBusinessID 得到AppKey,RequestData+AppKey的数据进行md5和base64后的内容就为YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE=(f) 接收方判断签名后的数据跟传递过来的DataSign是否一致,如果一致进行业务操作,如果不一直返回错误。9)、(C#)DataSign签名加密代码/<summary>/电商Sign签名/</summary
19、>/<param name="content">内容</param>/<param name="keyValue">Appkey</param>/<param name="charset">URL编码 </param>/<returns>DataSign签名</returns>Public String Encrypt (String content, String keyValue, String charset)if (keyVa
20、lue != null)return base64(MD5(content + keyValue, charset), charset);return base64(MD5(content, charset), charset);/<summary>/ 字符串MD5加密/</summary>/<param name="Text">要加密的字符串</param>/<returns>密文</returns>Private string MD5(string Text, string charset)byte
21、 buffer = System.Text.Encoding.GetEncoding(charset).GetBytes(Text);try System.Security.Cryptography.MD5CryptoServiceProvider check; check = new System.Security.Cryptography.MD5CryptoServiceProvider();byte somme = check.ComputeHash(buffer);string ret = ""foreach (byte a in somme) if (a <
22、 16) ret += "0" + a.ToString("X");else ret += a.ToString("X"); return ret.ToLower();catch throw; Private static string base64(String str, String charset)returnConvert.ToBase64String(System.Text.Encoding.GetEncoding(charset).GetBytes(str);10)、JAVA demoimport java.io.Buff
23、eredReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.OutputStreamWriter;import java.io.UnsupportedEncodingException;import .HttpURLConnection;import .URL;import .URLEncoder;import java.security.MessageDigest;import java.util.HashMap;import java.util.Map; public class
24、 KdniaoTrackQueryAPI /DEMOpublic static void main(String args) KdniaoTrackQueryAPI api = new KdniaoTrackQueryAPI();try String result = api.getOrderTracesByJson("ANE", "210001633605");System.out.print(result); catch (Exception e) e.printStackTrace();/电商IDprivate String EBusinessID
25、="请申请/电商加密私钥,注意保管,不要泄漏private String AppKey="请申请/请求urlprivate String ReqURL="http:/api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx" /* * Json方式 查询订单物流轨迹 * throws Exception */public String getOrderTracesByJson(String expCode, String expNo) throws ExceptionString requestData= &qu
26、ot;'OrderCode':'','ShipperCode':'" + expCode + "','LogisticCode':'" + expNo + "'"Map<String, String> params = new HashMap<String, String>();params.put("RequestData", urlEncoder(requestData, "UTF-8&quo
27、t;);params.put("EBusinessID", EBusinessID);params.put("RequestType", "1002");String dataSign=encrypt(requestData, AppKey, "UTF-8");params.put("DataSign", urlEncoder(dataSign, "UTF-8");params.put("DataType", "2");String r
28、esult=sendPost(ReqURL, params);/根据公司业务处理返回的信息.return result;/* * XML方式 查询订单物流轨迹 * throws Exception */public String getOrderTracesByXml() throws ExceptionString requestData= "<?xml version="1.0" encoding="utf-8" ?>"+"<Content>"+"<OrderCode&g
29、t;</OrderCode>"+"<ShipperCode>SF</ShipperCode>"+"<LogisticCode>589707398027</LogisticCode>"+"</Content>"Map<String, String> params = new HashMap<String, String>();params.put("RequestData", urlEncoder(request
30、Data, "UTF-8");params.put("EBusinessID", EBusinessID);params.put("RequestType", "1002");String dataSign=encrypt(requestData, AppKey, "UTF-8");params.put("DataSign", urlEncoder(dataSign, "UTF-8");params.put("DataType", &q
31、uot;1");String result=sendPost(ReqURL, params);/根据公司业务处理返回的信息.return result; /* * MD5加密 * param str 内容 * param charset 编码方式 * throws Exception */SuppressWarnings("unused")private String MD5(String str, String charset) throws Exception MessageDigest md = MessageDigest.getInstance("
32、;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 = resulti & 0xff; if (val <= 0xf) sb.append("0"); sb.append(Integer.toHexString(val); return sb.toString().toLowerCase()
33、;/* * base64编码 * param str 内容 * param charset 编码方式 * throws UnsupportedEncodingException */private String base64(String str, String charset) throws UnsupportedEncodingExceptionString encoded = base64Encode(str.getBytes(charset);return encoded; SuppressWarnings("unused")private String urlEn
34、coder(String str, String charset) throws UnsupportedEncodingExceptionString result = URLEncoder.encode(str, charset);return result;/* * 电商Sign签名生成 * param content 内容 * param keyValue Appkey * param charset 编码方式 * throws UnsupportedEncodingException ,Exception * return DataSign签名 */SuppressWarnings(&
35、quot;unused")private String encrypt (String content, String keyValue, String charset) throws UnsupportedEncodingException, Exceptionif (keyValue != null)return base64(MD5(content + keyValue, charset), charset);return base64(MD5(content, charset), charset); /* * 向指定 URL 发送POST方法的请求 * param url 发
36、送请求的 URL * param params 请求的参数集合 * return 远程资源的响应结果 */SuppressWarnings("unused")private String sendPost(String url, Map<String, String> params) OutputStreamWriter out = null; BufferedReader in = null; StringBuilder result = new StringBuilder(); try URL realUrl = new URL(url); HttpURLC
37、onnection conn =(HttpURLConnection) realUrl.openConnection(); / 发送POST请求必须设置如下两行 conn.setDoOutput(true); conn.setDoInput(true); / POST方法 conn.setRequestMethod("POST"); / 设置通用的请求属性 conn.setRequestProperty("accept", "*/*"); conn.setRequestProperty("connection",
38、"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 OutputSt
39、reamWriter(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("=&quo
40、t;); 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.ge
41、tInputStream(), "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
42、(); private static char base64EncodeChars = new char 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y',
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 草原草原生态补偿金分配与使用考核试卷
- 林业防火机械装备与应用考核试卷
- 探秘六年级模板
- 四年级学生成长解析
- 南京中医药大学《JAVA面向对象编程》2023-2024学年第二学期期末试卷
- 南京旅游职业学院《俄罗斯历史》2023-2024学年第二学期期末试卷
- 江苏省泰兴市济川中学2024-2025学年初三下学期5月练习数学试题含解析
- 吉林省长春市三中2025届4月高三学业水平考试生物试题试卷含解析
- 山东省诸城市龙源学校2024-2025学年中考化学试题冲刺试卷含解析
- 洛阳理工学院《生物材料研究的基础、前沿与应用》2023-2024学年第二学期期末试卷
- 中智公司招聘西飞笔试题
- 颜色分拣机器人工作站设计
- 深圳 退休 返聘 合同
- 湘科版科学六年级上册全册练习题(含答案)
- 成立物流协会可行性方案
- 《蛋白表达纯化》课件
- 苗木采购投标方案(技术方案)(技术方案)
- 附属房拆除方案模板
- JB-T 4088.1-2022 日用管状电热元件 第1部分:通用要求
- RLC串联电路暂态研究
- 《实数》单元作业设计
评论
0/150
提交评论