電子面單下單:api
5.3.1、請求接口以前須要先實名認證,開通相關會員服務,不然會請求失敗並返回提示「未申請開通接口」;app
5.3.2、接口開發需下載「快遞鳥接口技術文檔」、「2018快遞鳥接口支持快遞公司編碼列表.xlsx」、「快遞鳥電子面單客戶號參數對照表」、「快遞公司快遞業務類型」進行查看;電子面單,參考技術文檔中的3.2部分;ide
5.3.3、快遞鳥官網-幫助與文檔下載「電子面單demo」進行參考(僅提供了.NET、Java、PHP三種語言的demo);其餘語言開發的用戶需下載技術文檔自行開發;post
5.3.4、使用電子面單接口還須要電子面單帳號(注:每家快遞公司電子面單帳號須要傳的字段不一樣,詳情請參考「快遞鳥電子面單客戶號參數對照表」);測試
5.3.4.1、測試環境:必須使用快遞鳥提供的測試帳號,在快遞鳥官網-幫助與文檔下載「快遞鳥電子面單客戶號參數對照表」查看相應帳號和接口請求對應的字段名,另外電子面單接口測試環境由快遞公司維護,快遞公司常常調整致使測試環境不穩定甚至不可用,如:申通、宅急送、安能。正式環境是能夠正常使用的。測試環境只是提供給用戶調通接口使用,每家快遞鳥支持的快遞公司邏輯相同,測通一家快遞公司說明接口已調通。ui
5.3.4.二、正式環境:編碼
² 無需電子面單帳號直接下單:加密
順豐,EMS(廣東省內發全國),宅急送,郵政快遞包裹、中鐵快運、郵政國內標快、全一快遞;url
² 線上(快遞鳥官網後臺)申請帳號:spa
優速、韻達、圓通、遠成快運、安能、百世;
(申請路徑:快遞鳥官網—電子面單—個人快遞公司—申請新的快遞公司);
² 其餘的快遞公司您須要和當地的快遞網點線下申請帳號(預存單號)才能夠使用。
電子面單批量打印:
5.3.5、快遞鳥官網-幫助與文檔下載「電子面單批量打印demo」進行參考(僅提供了.NET、Java、PHP三種語言的demo);其餘語言開發的用戶需下載技術文檔自行開發;
5.3.6、對接注意事項
5.3.6.一、確保接口中電商ID、密鑰(AppKey)與用戶管理後臺的商戶ID、密鑰徹底一致;
5.3.6.二、OrderCode必須是快遞鳥電子面單下單接口正式環境下單的訂單號;PortName是打印機名稱,必須與本地
打印機名稱一致;
5.3.6.三、確保接口demo中GetIp()方法獲取到的IP和用戶鏈接打印機的電腦IP(百度搜索IP138)一致。
5.3.7、安裝快遞鳥打印控件C-Lodop (Print)
安裝方式一、調用快遞鳥批量打印demo後會提示下載。
安裝方式二、在快遞鳥官網下載,下載地址:http://www.kdniao.com/product-eorder-specific
demo示例:
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Text; using System.Web; namespace KdGoldAPI { /** * * 快遞鳥電子面單接口 * * @技術QQ * @技術QQ羣 * @see: http://www.kdniao.com/MiandanAPI.aspx * @copyright: 深圳市快金數據技術服務有限公司 * * ID和Key請到官網申請:http://www.kdniao.com/ServiceApply.aspx */ public class KdApiEOrderDemo { //電商ID private string EBusinessID = "請到快遞鳥官網申請http://www.kdniao.com/ServiceApply.aspx"; //電商加密私鑰,快遞鳥提供,注意保管,不要泄漏 private string AppKey = "請到快遞鳥官網申請http://www.kdniao.com/ServiceApply.aspx"; //請求url, 正式環境地址:http://api.kdniao.cc/api/Eorderservice private string ReqURL = "http://testapi.kdniao.cc:8081/api/EOrderService"; /// <summary> /// Json方式 電子面單 /// </summary> /// <returns></returns> public string orderTracesSubByJson() { string requestData = "{'OrderCode': '012657700312'," + "'ShipperCode':'YTO'," + "'PayType':1," + "'ExpType':1," + "'Cost':1.0," + "'OtherCost':1.0," + "'Sender':" + "{" + "'Company':'LV','Name':'Taylor','Mobile':'1xxxxxxxxxx','ProvinceName':'上海','CityName':'上海','ExpAreaName':'青浦區','Address':'明珠路73號'}," + "'Receiver':" + "{" + "'Company':'GCCUI','Name':'Yann','Mobile':'1xxxxxxxxxx','ProvinceName':'北京','CityName':'北京','ExpAreaName':'朝陽區','Address':'三里屯街道雅秀大廈'}," + "'Commodity':" + "[{" + "'GoodsName':'鞋子','Goodsquantity':1,'GoodsWeight':1.0}]," + "'AddService':" + "[{" + "'Name':'COD','Value':'1020'}]," + "'Weight':1.0," + "'Quantity':1," + "'Volume':0.0," + "'Remark':'當心輕放'," + "'IsReturnPrintTemplate':1}"; Dictionary<string, string> param = new Dictionary<string, string>(); param.Add("RequestData", HttpUtility.UrlEncode(requestData, Encoding.UTF8)); param.Add("EBusinessID", EBusinessID); param.Add("RequestType", "1007"); string dataSign = encrypt(requestData, AppKey, "UTF-8"); param.Add("DataSign", HttpUtility.UrlEncode(dataSign, Encoding.UTF8)); param.Add("DataType", "2"); string result = sendPost(ReqURL, param); //根據公司業務處理返回的信息...... return result; } /// <summary> /// Post方式提交數據,返回網頁的源代碼 /// </summary> /// <param name="url">發送請求的 URL</param> /// <param name="param">請求的參數集合</param> /// <returns>遠程資源的響應結果</returns> private string sendPost(string url, Dictionary<string, string> param) { string result = ""; StringBuilder postData = new StringBuilder(); if (param != null && param.Count > 0) { foreach (var p in param) { if (postData.Length > 0) { postData.Append("&"); } postData.Append(p.Key); postData.Append("="); postData.Append(p.Value); } } byte[] byteData = Encoding.GetEncoding("UTF-8").GetBytes(postData.ToString()); try { HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url); request.ContentType = "application/x-www-form-urlencoded"; request.Referer = url; request.Accept = "*/*"; request.Timeout = 30 * 1000; request.UserAgent = "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 2.0.50727; .NET CLR 3.0.04506.648; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729)"; request.Method = "POST"; request.ContentLength = byteData.Length; Stream stream = request.GetRequestStream(); stream.Write(byteData, 0, byteData.Length); stream.Flush(); stream.Close(); HttpWebResponse response = (HttpWebResponse)request.GetResponse(); Stream backStream = response.GetResponseStream(); StreamReader sr = new StreamReader(backStream, Encoding.GetEncoding("UTF-8")); result = sr.ReadToEnd(); sr.Close(); backStream.Close(); response.Close(); request.Abort(); } catch (Exception ex) { result = ex.Message; } return result; } ///<summary> ///電商Sign簽名 ///</summary> ///<param name="content">內容</param> ///<param name="keyValue">Appkey</param> ///<param name="charset">URL編碼 </param> ///<returns>DataSign簽名</returns> private string encrypt(String content, String keyValue, String charset) { if (keyValue != null) { return base64(MD5(content + keyValue, charset), charset); } return base64(MD5(content, charset), charset); } ///<summary> /// 字符串MD5加密 ///</summary> ///<param name="str">要加密的字符串</param> ///<param name="charset">編碼方式</param> ///<returns>密文</returns> private string MD5(string str, string charset) { byte[] buffer = System.Text.Encoding.GetEncoding(charset).GetBytes(str); 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; } } /// <summary> /// base64編碼 /// </summary> /// <param name="str">內容</param> /// <param name="charset">編碼方式</param> /// <returns></returns> private string base64(String str, String charset) { return Convert.ToBase64String(System.Text.Encoding.GetEncoding(charset).GetBytes(str)); } } }