電子面單下單:
5.3.1、請求接口之前需要先實名認證,開通相關會員服務,否則會請求失敗並返回提示“未申請開通接口”;
5.3.2、接口開發需下載“快遞鳥接口技術文檔”、“2018快遞鳥接口支持快遞公司編碼列表.xlsx”、“快遞鳥電子面單客戶號參數對照表”、“快遞公司快遞業務類型”進行查看;電子面單,參考技術文檔中的3.2部分;
5.3.3、快遞鳥官網-幫助與文檔下載“電子面單demo”進行參考(僅提供了.NET、Java、PHP三種語言的demo);其他語言開發的用戶需下載技術文檔自行開發;
5.3.4、使用電子面單接口還需要電子面單賬號(注:每家快遞公司電子面單賬號需要傳的字段不同,詳情請參考“快遞鳥電子面單客戶號參數對照表”);
5.3.4.1、測試環境:必須使用快遞鳥提供的測試賬號,在快遞鳥官網-幫助與文檔下載“快遞鳥電子面單客戶號參數對照表”查看相應賬號和接口請求對應的字段名,另外電子面單接口測試環境由快遞公司維護,快遞公司經常調整導致測試環境不穩定甚至不可用,如:申通、宅急送、安能。正式環境是可以正常使用的。測試環境只是提供給用戶調通接口使用,每家快遞鳥支持的快遞公司邏輯相同,測通一家快遞公司說明接口已調通。
5.3.4.2、正式環境:
² 無需電子面單賬號直接下單:
順豐,EMS(廣東省內發全國),宅急送,郵政快遞包裹、中鐵快運、郵政國內標快、全一快遞;
² 線上(快遞鳥官網后台)申請賬號:
優速、韻達、圓通、遠成快運、安能、百世;
(申請路徑:快遞鳥官網—電子面單—我的快遞公司—申請新的快遞公司);
² 其他的快遞公司您需要和當地的快遞網點線下申請賬號(預存單號)才可以使用。
電子面單批量打印:
5.3.5、快遞鳥官網-幫助與文檔下載“電子面單批量打印demo”進行參考(僅提供了.NET、Java、PHP三種語言的demo);其他語言開發的用戶需下載技術文檔自行開發;
5.3.6、對接注意事項
5.3.6.1、確保接口中電商ID、密鑰(AppKey)與用戶管理后台的商戶ID、密鑰完全一致;
5.3.6.2、OrderCode必須是快遞鳥電子面單下單接口正式環境下單的訂單號;PortName是打印機名稱,必須與本地
打印機名稱一致;
5.3.6.3、確保接口demo中GetIp()方法獲取到的IP和用戶連接打印機的電腦IP(百度搜索IP138)一致。
5.3.7、安裝快遞鳥打印控件C-Lodop (Print)
安裝方式1、調用快遞鳥批量打印demo后會提示下載。
安裝方式2、在快遞鳥官網下載,下載地址: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)); } } }