免费顺丰快递接口api对接调用demo.docx_第1页
免费顺丰快递接口api对接调用demo.docx_第2页
免费顺丰快递接口api对接调用demo.docx_第3页
免费顺丰快递接口api对接调用demo.docx_第4页
免费顺丰快递接口api对接调用demo.docx_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

免费顺丰快递接口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:,ShipperCode:SF,LogisticCode:1186508880182.返回没有物流轨迹的 EBusinessID: 1109259, Traces: , OrderCode: , ShipperCode: SF, LogisticCode: 118461988807, Success: false, Reason: null有物流轨迹的 EBusinessID: 1109259, OrderCode: , ShipperCode: SF, LogisticCode: 118461988807, Success: true, State: 3, Reason: null, Traces: AcceptTime: 2014/06/25 08:05:37, AcceptStation: 正在派件.(派件人:邓裕富,电话深圳 市, Remark: null , AcceptTime: 2014/06/25 04:01:28, AcceptStation: 快件在 深圳集散中心 ,准备送往下一站 深圳 深圳市, Remark: null , AcceptTime: 2014/06/25 01:41:06, AcceptStation: 快件在 深圳集散中心 深圳市, Remark: null , AcceptTime: 2014/06/24 20:18:58, AcceptStation: 已收件深圳市, Remark: null , AcceptTime: 2014/06/24 20:55:28, AcceptStation: 快件在 深圳 ,准备送往下一站 深圳集散中心 深圳市, Remark: null , AcceptTime: 2014/06/25 10:23:03, AcceptStation: 派件已签收深圳市, Remark: null , AcceptTime: 2014/06/25 10:23:03, AcceptStation: 签收人是:已签收深圳市, Remark: null 注:接口及签名说明1)、支持http传输协议2)、支持的数据传输格式 Json/Xml(暂不支持这种形式)。 编码格式:UTF-8 交互协议上统一用UTF-8,避免传递中文数据出现乱码。3)、接入步骤 注册成为用户(注:注册成功选择服务立即使用,无需审批)。注册成功后,登录就可以查看ID和key。 注册方式通过网络平台:按照接口官网提示进行注册申请,注册成功并且登录,将得到一组电商ID和AppKey。电商ID是调用接口服务的身份证明,不可更改、不可转用,AppKey是应用访问API的签名附加密钥,必须妥善保存。两者关系类似于登录帐号和密码,两者都会在签名和业务参数中使用。注册成功登录之后认证:即可申请接口 申请后ID和KEY自动激活(1) 开发服务开发自身业务的服务,服务需按照后面接口的定义规则。(2) 查看接口调用的DEMO物流技术接口提供调用物流接口的DEMO(.Net版本),包括网上在线订单下单、物流轨迹查询等物流行业标准化的下单操作流程与数据查询格式。提交接入处理的相关代码如有不明白的地方可与物流技术接口人协作开发。DEMO下载地址:/download 4)、接口数据包结构图例 - 数据包结构 (系统级数据)5)、XML范例/JSON 范例 string userID = 1109259; string keyValue = 56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17;/加密私钥,由发货通提供 string url = http:/api.kdniao.cc:8081/Ebusiness/EbusinessOrderHandle.aspx; /请求地址 string DataType = 1; /1-xml;2-json string charset=UTF-8;/字符编码采用UTF-8 string xmlStr = SF118650888088;/ XML字符串 string xmlStr = OrderCode:,ShipperCode:SF,LogisticCode:118461988807; / JSON字符串string datasign = MD5(xmlStr+keyValue, UTF-8);/生成加密签名加密通过对参数xmlStr+ 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/EbusinessOrderHandle.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=数据内容(URL编码:UTF-8)DataSign= 签名摘要(URL编码:UTF-8(base64(MD5(数据内容 +AppKey)1个可选参数:DataType=返回数据类型(1-xml,2-json;默认为2格式)注:DataSign生成后,对方接收到数据后,以同样的算法进行签名,生成摘要,对比两者的摘要是否相同,如果不同,说明传递过程中发生数据篡改,对接过程中如有不明白之处可双方技术协作进行(2) 调用接口的身份认证注册成为接口用户后,会生成对应的电商ID和AppKey,电商ID相当于用户名,AppKey相当于密码。注:请勿遗漏或传递可能递增大接口调用维护举例说明:(a) 假设RequestData (XML)内容为: SF118954907573,经过URL(UTF-8)编码的内容为%3cContent%3e%3cShipperCode%3eSF%3c%2fShipperCode%3e%3cLogisticCode%3e118954907573%3c%2fLogisticCode%3e%3c%2fContent%3e, EBusinessID为1109259,AppKey为56da2cf8-c8a2-44b2-b6fa-476cd7d1ba17(b) 那么DataSign签名的内容为SF11895490757356da2cf8-c8a2-44b2-b6fa-476cd7d1ba17,经过md5和base64后的内容就为YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE=,在经过URL(UTF-8)编码的内容为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%3d& DataType=2(d) 接收方收到数据后,获得EBusinessID 和RequestData和DataSign等这几个数据。(e) 接收方对EBusinessID 得到AppKey,RequestData+AppKey的数据进行md5和base64后的内容就为YzBjODA3MjA2NmViM2ZlZGMyNWNjMDA0NDRiMDdmOTE=(f) 接收方判断签名后的数据跟传递过来的DataSign是否一致,如果一致进行业务操作,如果不一直返回错误。9)、(C#)DataSign签名加密代码/电商Sign签名/内容/Appkey/URL编码 /DataSign签名Public String Encrypt (String content, String keyValue, String charset)if (keyValue != null)return base64(MD5(content + keyValue, charset), charset);return base64(MD5(content, charset), charset);/ 字符串MD5加密/要加密的字符串/密文Private string MD5(string Text, string charset)byte 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 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.BufferedReader;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 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=请申请/ServiceApply.aspx;/电商加密私钥,注意保管,不要泄漏private String AppKey=请申请/ServiceApply.aspx;/请求urlprivate String ReqURL=http:/api.kdniao.cc/Ebusiness/EbusinessOrderHandle.aspx; /* * Json方式 查询订单物流轨迹 * throws Exception */public String getOrderTracesByJson(String expCode, String expNo) throws ExceptionString requestData= OrderCode:,ShipperCode: + expCode + ,LogisticCode: + expNo + ;Map params = new HashMap();params.put(RequestData, urlEncoder(requestData, 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, 2);String result=sendPost(ReqURL, params);/根据公司业务处理返回的信息.return result;/* * XML方式 查询订单物流轨迹 * throws Exception */public String getOrderTracesByXml() throws ExceptionString requestData= +SF+589707398027+;Map params = new HashMap();params.put(RequestData, urlEncoder(requestData, 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, 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(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();/* * 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 urlEncoder(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(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 发送请求的 URL * param 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 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的

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论