SetDepositPostService.cs 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404
  1. using System;
  2. using System.Collections.Generic;
  3. using Library;
  4. using LitJson;
  5. using System.Linq;
  6. using System.Data;
  7. using System.Threading;
  8. using MySystem.PxcModels;
  9. using System.Security.Cryptography;
  10. using System.Text;
  11. namespace MySystem
  12. {
  13. public class SetDepositPostService
  14. {
  15. public readonly static SetDepositPostService Instance = new SetDepositPostService();
  16. private SetDepositPostService()
  17. { }
  18. public void Start()
  19. {
  20. Thread th = new Thread(dosomething);
  21. th.IsBackground = true;
  22. th.Start();
  23. }
  24. public void dosomething()
  25. {
  26. while (true)
  27. {
  28. string data = RedisDbconn.Instance.RPop<string>("SetDepositPostQueue");
  29. if (!string.IsNullOrEmpty(data))
  30. {
  31. try
  32. {
  33. WebCMSEntities db = new WebCMSEntities();
  34. JsonData jsonObj = JsonMapper.ToObject(data);
  35. string PosIds = jsonObj["PosId"].ToString();
  36. int Kind = int.Parse(function.CheckInt(jsonObj["Kind"].ToString()));
  37. int RecordId = 0;
  38. if(data.Contains("\"RecordId\""))
  39. {
  40. RecordId = int.Parse(function.CheckInt(jsonObj["RecordId"].ToString()));
  41. }
  42. string OpMan = jsonObj["OpMan"].ToString();
  43. if(!string.IsNullOrEmpty(PosIds) && Kind > 0)
  44. {
  45. List<int> ids = new List<int>();
  46. string[] PosIdList = PosIds.Split(',');
  47. foreach(string sub in PosIdList)
  48. {
  49. ids.Add(int.Parse(sub));
  50. }
  51. List<KqProducts> brands = db.KqProducts.ToList();
  52. List<PosMachinesTwo> poslist = db.PosMachinesTwo.Where(m => ids.Contains(m.Id)).ToList();
  53. List<int> mids = poslist.Select(m => m.BindMerchantId).ToList();
  54. List<PosMerchantInfo> merchantlist = db.PosMerchantInfo.Where(m => mids.Contains(m.Id)).ToList();
  55. Dictionary<int, List<PosMachinesTwo>> userPosList = new Dictionary<int, List<PosMachinesTwo>>();
  56. foreach(PosMachinesTwo pos in poslist)
  57. {
  58. PosMerchantInfo merchant = merchantlist.FirstOrDefault(m => m.Id == pos.BindMerchantId);
  59. if(merchant != null)
  60. {
  61. decimal Fee = Kind == 1 ? 0.63M : 0.6M;
  62. if(pos.BrandId == 1 || pos.BrandId == 3) //金控
  63. {
  64. string content = function.GetWebRequest("http://connect.kexiaoshuang.com/home/setfee?merNo=" + merchant.KqMerNo + "&sn=" + pos.PosSn + "&fee=" + Fee);
  65. if(content.Contains("|"))
  66. {
  67. content = content.Split("|")[1];
  68. JsonData obj = JsonMapper.ToObject(content);
  69. if(obj["errorCode"].ToString() == "0000")
  70. {
  71. pos.SeoDescription = "设置成功";
  72. SetRecordResult(db, RecordId, 1, "设置成功");
  73. db.SaveChanges();
  74. }
  75. else
  76. {
  77. string msg = obj["errorCodeDesc"].ToString();
  78. pos.SeoDescription = msg;
  79. SetRecordResult(db, RecordId, -1, msg);
  80. db.SaveChanges();
  81. }
  82. }
  83. else
  84. {
  85. JsonData obj = JsonMapper.ToObject(content);
  86. string msg = obj["message"].ToString();
  87. pos.SeoDescription = msg;
  88. SetRecordResult(db, RecordId, -1, msg);
  89. db.SaveChanges();
  90. }
  91. }
  92. // else if(pos.BrandId == 6) //立刷
  93. // {
  94. // string content = SetLiSFee(pos.PosSn, Fee);
  95. // JsonData obj = JsonMapper.ToObject(content);
  96. // if (obj["ret_code"].ToString() == "00")
  97. // {
  98. // if(Kind == 1)
  99. // {
  100. // pos.UpFeeFlag = 1;
  101. // pos.UpFeeMan = OpMan;
  102. // pos.UpFeeDate = DateTime.Now;
  103. // }
  104. // else if(Kind == 2)
  105. // {
  106. // pos.DownFeeFlag = 1;
  107. // pos.DownFeeMan = OpMan;
  108. // pos.DownFeeDate = DateTime.Now;
  109. // SetRecordResult(db, RecordId, 1);
  110. // }
  111. // db.SaveChanges();
  112. // pos.QueryCount = Kind;
  113. // if(userPosList.ContainsKey(pos.BuyUserId))
  114. // {
  115. // userPosList[pos.BuyUserId].Add(pos);
  116. // }
  117. // else
  118. // {
  119. // List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  120. // subPos.Add(pos);
  121. // userPosList.Add(pos.BuyUserId, subPos);
  122. // }
  123. // }
  124. // else
  125. // {
  126. // string msg = obj["ret_msg"].ToString();
  127. // pos.SeoDescription = msg;
  128. // SetRecordResult(db, RecordId, -1, msg);
  129. // db.SaveChanges();
  130. // }
  131. // }
  132. }
  133. }
  134. foreach(int UserId in userPosList.Keys)
  135. {
  136. string snhtml = "", snhtml2 = "";
  137. foreach (var items in userPosList[UserId])
  138. {
  139. var mer = merchantlist.FirstOrDefault(m => m.Id == items.BindMerchantId) ?? new PosMerchantInfo();
  140. var brand = brands.FirstOrDefault(m => m.Id == items.BrandId) ?? new KqProducts();
  141. if(items.QueryCount == 1)
  142. {
  143. snhtml += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  144. snhtml += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  145. snhtml += "<div class='f12'>SN:" + items.PosSn + "</div>";
  146. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  147. }
  148. else if(items.QueryCount == 2)
  149. {
  150. snhtml2 += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  151. snhtml2 += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  152. snhtml2 += "<div class='f12'>SN:" + items.PosSn + "</div>";
  153. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  154. snhtml2 += "<div class='f12'>当前费率:0.6%</div>";
  155. snhtml2 += "<div class='f12'>费率调整时间:" + DownFeeDate + "</div>";
  156. }
  157. }
  158. if(!string.IsNullOrEmpty(snhtml))
  159. {
  160. snhtml = "<div style='margin-bottom: .48rem;'>" + snhtml + "</div>";
  161. RedisDbconn.Instance.AddList("MsgPersonalQueue", Newtonsoft.Json.JsonConvert.SerializeObject(new MsgPersonal()
  162. {
  163. UserId = Convert.ToInt32(UserId), //创客
  164. Title = "商户费率变更通知", //标题
  165. Content = "<div class='f12' style='margin-bottom: .72rem'>您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率</div>" + snhtml, //内容
  166. Summary = "您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率",
  167. CreateDate = DateTime.Now,
  168. }));
  169. }
  170. else if(!string.IsNullOrEmpty(snhtml2))
  171. {
  172. snhtml2 = "<div style='margin-bottom: .48rem;'>" + snhtml2 + "</div>";
  173. RedisDbconn.Instance.AddList("MsgPersonalQueue", Newtonsoft.Json.JsonConvert.SerializeObject(new MsgPersonal()
  174. {
  175. UserId = Convert.ToInt32(UserId), //创客
  176. Title = "商户费率变更通知", //标题
  177. Content = "<div class='f12' style='margin-bottom: .72rem'>您的商户刷卡交易费率已变更成功!</div>" + snhtml2, //内容
  178. Summary = "您的商户刷卡交易费率已变更成功!",
  179. CreateDate = DateTime.Now,
  180. }));
  181. }
  182. }
  183. }
  184. db.Dispose();
  185. }
  186. catch (Exception ex)
  187. {
  188. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "设置费率队列异常");
  189. }
  190. }
  191. else
  192. {
  193. Thread.Sleep(60000);
  194. }
  195. }
  196. }
  197. private void SetRecordResult(WebCMSEntities db, int RecordId, int Status, string Note = "")
  198. {
  199. if(RecordId > 0)
  200. {
  201. PosMachinesFeeChangeRecord record = db.PosMachinesFeeChangeRecord.FirstOrDefault(m => m.Id == RecordId);
  202. if(record != null)
  203. {
  204. record.Status = Status;
  205. record.SeoDescription = Note;
  206. }
  207. }
  208. }
  209. #region 金控
  210. // 开发环境
  211. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  212. // string mfe88PrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBALLxyDr+1dtKPaLW3KLtXO3AnDu42apzdtLqxUhmQNiFOZxeGlXXuOriPbPP+1RHBfxvcx0rUDUdNHVdF3uGXTDZQX2IWTpR7MHInm100Oh98wIYm1VJOGr4wJX5ZAjbq0n+5vpubsY+vNNHv1+e036dOeJEzi2uM403ZbMSEcRzAgMBAAECgYAeRbb4/AmTypB4zt6OlZdGBXKoy9HO+y+b6OmtINdRieBAKs9LvG3lFpcXp1S+YjGKDhSsV5p/EczBGhmR5R44j52886h6OoU0HskifeEJs152gMXLEFya/1QWnf1Ev+ugzuto+CxuHlGHE0T43uFkuATZp4sfXX/03um99FIKmQJBAOrYJX+VmKdNbmwNKMXkFBAw6FM4wrtr6vT3ne0pBWgbUDIH8cs83wq/SQHuvy/Cafqr8qWC9fFX2m+hllzxzA0CQQDDEIDNXdRxEmRVQ90lnn6ppnERvLhTY3RyuyOj3aqM1lxWEU2vvylimCpccTEqgY/PqMwfqChSf2v3S2CFjzJ/AkAPw2ho8vKnMDRcPlnhRpjuKUo+4812ZR0FSmWoWJuLTGIKqavaN4DFKOfOoGbm3sbcU5Ra9bpqc7ouygrcvEI1AkB8uqbBqsfW7X2+j8Bu96Picw1F3Di5CZVCb6tgcrNFjyRH3JSiVkfuRYKAzdg0Z9g/Xp33eB0gc13kKQy1GlWdAkB6Emn94YesoHda26HWbrgBy18KSfcLH57EuXquX/pOma1TXjaXw1E7kkFz1EPde9WzuSWUmGN2AdJT0ruTOb4C";
  213. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  214. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  215. // string reqUrl = "https://test-push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  216. // 生产环境
  217. string merchantNo = "4487378308096";
  218. string clientId = "1243966544896";
  219. string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
  220. string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
  221. string clientPrivateKey = "MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKtKs0qQG39fwWR3u+IalMyT4Z0mAT5K+gDg9KNxylmgtafDFewLwr/ul+b24bE+O1717hHOdcTme6FKtx+WziUNaFOsZ3+WPch3w4Iz7IQb7GKUmzWW9cmMcOEvr/Br5MTk1LNagqBefJ4cXdNIcxtR58su2gqovePiHiU+quOJAgMBAAECgYBQIIyIR6slRWTRG5V/KlIK9O5oNbwFKMuUF6c4weUXUi9Hv+GEXugGIpVaTIi9AdCCFmb8W2kJ54tTowDQvRnGxVpr7repYwJv2jHh5ug3oreBghfbfbaOaRMXisp2x1CLi+8Q5BNjpe9KdurRtg7jt8bqgWels5aV2PbjPHHwBQJBANjqYXbapz6xUPdI0kyEQhdxHt7jOmysTY3vT+/UcgU2sf37hWh8JlTtVlFZns3JBocc9rMtBEAh0Cy5faMQXKMCQQDKJ9eYWQvb1GyB5IdDlkOuByyuwFfosZ0Qp+QNtnz1VAHHgQRM7RGNv3nYDJNEJ+qIhIzZppG5yDbAN7PYyTXjAkEAq8a4VkIDbZ9HyfxOJbAbEqtPUhzJ+KNea0cXm4o2nTBaNhLH7B1c0aZ908BQBRDr7XWfW/cLRapBTBm8h7R+VwJBAJAKrZMPN+TuSlaPaFYfNqBE2nC1+q2CCQE6L8QZmJYRwqbN5iuN7CkNGxt3cmNo8bNOhzH6fvFamLCDwDEixbMCQEgaxfAxpJdMoR6LrklSkigHiKfA6SaRWxxShFtBfjk5XcakmLkU/U5lgD/Blu7h4x6bRf4VPTYWdbxtiOK11rY=";
  222. string reqUrl = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  223. public string SetJkFee(string merNo, string sn, decimal fee = 0.6M)
  224. {
  225. List<SetDepositList> rateDOs = new List<SetDepositList>();
  226. rateDOs.Add(new SetDepositList()
  227. {
  228. productSubType = "2020032007vz7Ux6",
  229. updateValue = fee,
  230. updateType = 0
  231. });
  232. Dictionary<string, string> headers = new Dictionary<string, string>();
  233. headers.Add("X-Client-ID", clientId);
  234. headers.Add("X-Security", "RSA");
  235. Dictionary<string, object> obj = new Dictionary<string, object>();
  236. obj.Add("merNo", merNo);
  237. obj.Add("sn", sn);
  238. obj.Add("batchUpdateType", 2);
  239. obj.Add("rateDOs", rateDOs);
  240. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  241. function.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  242. function.WriteLog(content, "设置金控机具费率");
  243. content = Encrypt(content);
  244. string signstr = Sign(content);
  245. headers.Add("X-Sign", signstr);
  246. string req = "{\"param\":\"" + content + "\"}";
  247. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  248. function.WriteLog(result, "设置金控机具费率");
  249. return result;
  250. }
  251. public string Decrypt(string data)
  252. {
  253. var toDecryptArray = Convert.FromBase64String(data);
  254. var rsa = RSA.Create();
  255. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  256. string result = "";
  257. List<byte> cache = new List<byte>();
  258. for (int i = 0; i < toDecryptArray.Length; i++)
  259. {
  260. cache.Add(toDecryptArray[i]);
  261. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  262. {
  263. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  264. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  265. cache.Clear();
  266. }
  267. }
  268. return result;
  269. }
  270. public string Encrypt(string data)
  271. {
  272. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  273. }
  274. public string Sign(string data)
  275. {
  276. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  277. var rsa = RSA.Create();
  278. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  279. string result = "";
  280. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  281. result = Convert.ToBase64String(buffer);
  282. return result;
  283. }
  284. #endregion
  285. #region 立刷
  286. string LiSAgentId = "50814834";
  287. string LiSPrivateKey = "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";
  288. string LiSReqUrl = "https://openapi.jlpay.com/access/charge/"; //请求url
  289. public string LiSSign(string data)
  290. {
  291. var rsa = RSA.Create();
  292. var key = Convert.FromBase64String(LiSPrivateKey);
  293. var content = Encoding.UTF8.GetBytes(data);
  294. rsa.ImportPkcs8PrivateKey(key, out _);
  295. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  296. return Convert.ToBase64String(result);
  297. }
  298. // 设置费率
  299. public string SetLiSFee(string sn, decimal serviceFee = 0.6M)
  300. {
  301. Dictionary<string, object> dic = new Dictionary<string, object>();
  302. dic.Add("agentId", LiSAgentId);
  303. dic.Add("deviceSn", sn);
  304. List<Dictionary<string, object>> feeList = new List<Dictionary<string, object>>();
  305. Dictionary<string, object> item = new Dictionary<string, object>();
  306. item.Add("feeCalcType", "M5");
  307. item.Add("fixed", "0");
  308. item.Add("rate", serviceFee);
  309. feeList.Add(item);
  310. dic.Add("feeList", feeList);
  311. dic.Add("signMethod", "02");
  312. string content = LiSAgentId + sn + "M50" + serviceFee + "02";
  313. string signstr = LiSSign(content);
  314. dic.Add("signData", signstr);
  315. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  316. function.WriteLog(DateTime.Now.ToString(), "设置立刷费率");
  317. function.WriteLog(req, "设置立刷费率");
  318. string result = PostWebRequest(LiSReqUrl + "FEE003", req, new Dictionary<string, string>());
  319. function.WriteLog(result, "设置立刷费率");
  320. function.WriteLog("\n\n", "设置立刷费率");
  321. return result;
  322. }
  323. public string QueryLiSDeposit(string merchNo, string sn)
  324. {
  325. Dictionary<string, object> dic = new Dictionary<string, object>();
  326. dic.Add("agentId", LiSAgentId);
  327. dic.Add("deviceSn", sn);
  328. dic.Add("merchNo", merchNo);
  329. dic.Add("signMethod", "02");
  330. string content = LiSAgentId + sn + merchNo + "02";
  331. string signstr = LiSSign(content);
  332. dic.Add("signData", signstr);
  333. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  334. string result = PostWebRequest(LiSReqUrl + "FEE001", req, new Dictionary<string, string>());
  335. return result;
  336. }
  337. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  338. {
  339. string ret = string.Empty;
  340. try
  341. {
  342. function.WriteLog(DateTime.Now.ToString(), "请求开店宝API日志");
  343. function.WriteLog(postUrl, "请求开店宝API日志");
  344. function.WriteLog(paramData, "请求开店宝API日志");
  345. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  346. // 设置提交的相关参数
  347. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  348. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  349. request.Method = "POST";
  350. request.KeepAlive = false;
  351. request.AllowAutoRedirect = true;
  352. request.ContentType = "application/json";
  353. foreach (string key in headers.Keys)
  354. {
  355. request.Headers.Add(key, headers[key]);
  356. }
  357. 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.5.21022; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729)";
  358. request.ContentLength = postData.Length;
  359. // 提交请求数据
  360. System.IO.Stream outputStream = request.GetRequestStream();
  361. outputStream.Write(postData, 0, postData.Length);
  362. outputStream.Close();
  363. System.Net.HttpWebResponse response;
  364. System.IO.Stream responseStream;
  365. System.IO.StreamReader reader;
  366. string srcString;
  367. response = request.GetResponse() as System.Net.HttpWebResponse;
  368. responseStream = response.GetResponseStream();
  369. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  370. srcString = reader.ReadToEnd();
  371. ret = srcString; //返回值赋值
  372. reader.Close();
  373. function.WriteLog(srcString, "请求开店宝API日志");
  374. }
  375. catch (Exception ex)
  376. {
  377. ret = "fail";
  378. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  379. }
  380. return ret;
  381. }
  382. #endregion
  383. }
  384. }