SetDepositService.cs 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396
  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 SetDepositService
  14. {
  15. public readonly static SetDepositService Instance = new SetDepositService();
  16. private SetDepositService()
  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>("SetDepositQueue");
  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. string OpMan = jsonObj["OpMan"].ToString();
  38. if(!string.IsNullOrEmpty(PosIds) && Kind > 0)
  39. {
  40. List<int> ids = new List<int>();
  41. string[] PosIdList = PosIds.Split(',');
  42. foreach(string sub in PosIdList)
  43. {
  44. ids.Add(int.Parse(sub));
  45. }
  46. List<KqProducts> brands = db.KqProducts.ToList();
  47. List<PosMachinesTwo> poslist = db.PosMachinesTwo.Where(m => ids.Contains(m.Id)).ToList();
  48. List<int> mids = poslist.Select(m => m.BindMerchantId).ToList();
  49. List<PosMerchantInfo> merchantlist = db.PosMerchantInfo.Where(m => mids.Contains(m.Id)).ToList();
  50. Dictionary<int, List<PosMachinesTwo>> userPosList = new Dictionary<int, List<PosMachinesTwo>>();
  51. foreach(PosMachinesTwo pos in poslist)
  52. {
  53. PosMerchantInfo merchant = merchantlist.FirstOrDefault(m => m.Id == pos.BindMerchantId);
  54. if(merchant != null)
  55. {
  56. decimal Fee = Kind == 1 ? 0.63M : 0.6M;
  57. if(pos.BrandId == 1 || pos.BrandId == 3) //金控
  58. {
  59. string content = SetDeposit(merchant.KqMerNo, pos.PosSn, Fee);
  60. JsonData obj = JsonMapper.ToObject(content);
  61. if (obj["code"].ToString() == "0000")
  62. {
  63. content = Decrypt(obj["data"].ToString());
  64. JsonData contentObj = JsonMapper.ToObject(content);
  65. if (contentObj["respCode"].ToString() == "00")
  66. {
  67. if(Kind == 1)
  68. {
  69. pos.UpFeeFlag = 1;
  70. pos.UpFeeMan = OpMan;
  71. pos.UpFeeDate = DateTime.Now;
  72. }
  73. else if(Kind == 2)
  74. {
  75. pos.DownFeeFlag = 1;
  76. pos.DownFeeMan = OpMan;
  77. pos.DownFeeDate = DateTime.Now;
  78. }
  79. db.SaveChanges();
  80. pos.QueryCount = Kind;
  81. if(userPosList.ContainsKey(pos.BuyUserId))
  82. {
  83. userPosList[pos.BuyUserId].Add(pos);
  84. }
  85. else
  86. {
  87. List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  88. subPos.Add(pos);
  89. userPosList.Add(pos.BuyUserId, subPos);
  90. }
  91. }
  92. else
  93. {
  94. string msg = contentObj["respMsg"].ToString();
  95. pos.SeoDescription = msg;
  96. db.SaveChanges();
  97. }
  98. }
  99. else
  100. {
  101. string msg = obj["message"].ToString();
  102. pos.SeoDescription = msg;
  103. db.SaveChanges();
  104. }
  105. }
  106. else if(pos.BrandId == 6) //立刷
  107. {
  108. string content = SetLiSFee(pos.PosSn, Fee);
  109. JsonData obj = JsonMapper.ToObject(content);
  110. if (obj["ret_code"].ToString() == "00")
  111. {
  112. if(Kind == 1)
  113. {
  114. pos.UpFeeFlag = 1;
  115. pos.UpFeeMan = OpMan;
  116. pos.UpFeeDate = DateTime.Now;
  117. }
  118. else if(Kind == 2)
  119. {
  120. pos.DownFeeFlag = 1;
  121. pos.DownFeeMan = OpMan;
  122. pos.DownFeeDate = DateTime.Now;
  123. }
  124. db.SaveChanges();
  125. pos.QueryCount = Kind;
  126. if(userPosList.ContainsKey(pos.BuyUserId))
  127. {
  128. userPosList[pos.BuyUserId].Add(pos);
  129. }
  130. else
  131. {
  132. List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  133. subPos.Add(pos);
  134. userPosList.Add(pos.BuyUserId, subPos);
  135. }
  136. }
  137. else
  138. {
  139. string msg = obj["ret_msg"].ToString();
  140. pos.SeoDescription = msg;
  141. db.SaveChanges();
  142. }
  143. }
  144. }
  145. }
  146. foreach(int UserId in userPosList.Keys)
  147. {
  148. string snhtml = "", snhtml2 = "";
  149. foreach (var items in userPosList[UserId])
  150. {
  151. var mer = merchantlist.FirstOrDefault(m => m.Id == items.BindMerchantId) ?? new PosMerchantInfo();
  152. var brand = brands.FirstOrDefault(m => m.Id == items.BrandId) ?? new KqProducts();
  153. if(items.QueryCount == 1)
  154. {
  155. snhtml += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  156. snhtml += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  157. snhtml += "<div class='f12'>SN:" + items.PosSn + "</div>";
  158. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  159. }
  160. else if(items.QueryCount == 2)
  161. {
  162. snhtml2 += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  163. snhtml2 += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  164. snhtml2 += "<div class='f12'>SN:" + items.PosSn + "</div>";
  165. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  166. snhtml2 += "<div class='f12'>当前费率:0.6%</div>";
  167. snhtml2 += "<div class='f12'>费率调整时间:" + DownFeeDate + "</div>";
  168. }
  169. }
  170. if(!string.IsNullOrEmpty(snhtml))
  171. {
  172. snhtml = "<div style='margin-bottom: .48rem;'>" + snhtml + "</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'>您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率</div>" + snhtml, //内容
  178. Summary = "您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率",
  179. CreateDate = DateTime.Now,
  180. }));
  181. }
  182. else if(!string.IsNullOrEmpty(snhtml2))
  183. {
  184. snhtml2 = "<div style='margin-bottom: .48rem;'>" + snhtml2 + "</div>";
  185. RedisDbconn.Instance.AddList("MsgPersonalQueue", Newtonsoft.Json.JsonConvert.SerializeObject(new MsgPersonal()
  186. {
  187. UserId = Convert.ToInt32(UserId), //创客
  188. Title = "商户费率变更通知", //标题
  189. Content = "<div class='f12' style='margin-bottom: .72rem'>您的商户刷卡交易费率已变更成功!</div>" + snhtml2, //内容
  190. Summary = "您的商户刷卡交易费率已变更成功!",
  191. CreateDate = DateTime.Now,
  192. }));
  193. }
  194. }
  195. }
  196. db.Dispose();
  197. }
  198. catch (Exception ex)
  199. {
  200. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "设置费率队列异常");
  201. }
  202. }
  203. else
  204. {
  205. Thread.Sleep(60000);
  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 SetDeposit(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. content = Encrypt(content);
  242. string signstr = Sign(content);
  243. headers.Add("X-Sign", signstr);
  244. string req = "{\"param\":\"" + content + "\"}";
  245. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  246. return result;
  247. }
  248. public string Decrypt(string data)
  249. {
  250. var toDecryptArray = Convert.FromBase64String(data);
  251. var rsa = RSA.Create();
  252. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  253. string result = "";
  254. List<byte> cache = new List<byte>();
  255. for (int i = 0; i < toDecryptArray.Length; i++)
  256. {
  257. cache.Add(toDecryptArray[i]);
  258. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  259. {
  260. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  261. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  262. cache.Clear();
  263. }
  264. }
  265. return result;
  266. }
  267. public string Encrypt(string data)
  268. {
  269. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  270. }
  271. public string Sign(string data)
  272. {
  273. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  274. var rsa = RSA.Create();
  275. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  276. string result = "";
  277. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  278. result = Convert.ToBase64String(buffer);
  279. return result;
  280. }
  281. #endregion
  282. #region 立刷
  283. string LiSAgentId = "50814834";
  284. string LiSPrivateKey = "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";
  285. string LiSReqUrl = "https://openapi.jlpay.com/access/charge/"; //请求url
  286. public string LiSSign(string data)
  287. {
  288. var rsa = RSA.Create();
  289. var key = Convert.FromBase64String(LiSPrivateKey);
  290. var content = Encoding.UTF8.GetBytes(data);
  291. rsa.ImportPkcs8PrivateKey(key, out _);
  292. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  293. return Convert.ToBase64String(result);
  294. }
  295. // 设置费率
  296. public string SetLiSFee(string sn, decimal serviceFee = 0.6M)
  297. {
  298. Dictionary<string, object> dic = new Dictionary<string, object>();
  299. dic.Add("agentId", LiSAgentId);
  300. dic.Add("deviceSn", sn);
  301. List<Dictionary<string, object>> feeList = new List<Dictionary<string, object>>();
  302. Dictionary<string, object> item = new Dictionary<string, object>();
  303. item.Add("feeCalcType", "M5");
  304. item.Add("fixed", "0");
  305. item.Add("rate", serviceFee);
  306. feeList.Add(item);
  307. dic.Add("feeList", feeList);
  308. dic.Add("signMethod", "02");
  309. string content = LiSAgentId + sn + "M50" + serviceFee + "02";
  310. string signstr = LiSSign(content);
  311. dic.Add("signData", signstr);
  312. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  313. string result = PostWebRequest(LiSReqUrl + "FEE003", req, new Dictionary<string, string>());
  314. return result;
  315. }
  316. public string QueryLiSDeposit(string merchNo, string sn)
  317. {
  318. Dictionary<string, object> dic = new Dictionary<string, object>();
  319. dic.Add("agentId", LiSAgentId);
  320. dic.Add("deviceSn", sn);
  321. dic.Add("merchNo", merchNo);
  322. dic.Add("signMethod", "02");
  323. string content = LiSAgentId + sn + merchNo + "02";
  324. string signstr = LiSSign(content);
  325. dic.Add("signData", signstr);
  326. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  327. string result = PostWebRequest(LiSReqUrl + "FEE001", req, new Dictionary<string, string>());
  328. return result;
  329. }
  330. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  331. {
  332. string ret = string.Empty;
  333. try
  334. {
  335. function.WriteLog(DateTime.Now.ToString(), "请求开店宝API日志");
  336. function.WriteLog(postUrl, "请求开店宝API日志");
  337. function.WriteLog(paramData, "请求开店宝API日志");
  338. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  339. // 设置提交的相关参数
  340. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  341. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  342. request.Method = "POST";
  343. request.KeepAlive = false;
  344. request.AllowAutoRedirect = true;
  345. request.ContentType = "application/json";
  346. foreach (string key in headers.Keys)
  347. {
  348. request.Headers.Add(key, headers[key]);
  349. }
  350. 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)";
  351. request.ContentLength = postData.Length;
  352. // 提交请求数据
  353. System.IO.Stream outputStream = request.GetRequestStream();
  354. outputStream.Write(postData, 0, postData.Length);
  355. outputStream.Close();
  356. System.Net.HttpWebResponse response;
  357. System.IO.Stream responseStream;
  358. System.IO.StreamReader reader;
  359. string srcString;
  360. response = request.GetResponse() as System.Net.HttpWebResponse;
  361. responseStream = response.GetResponseStream();
  362. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  363. srcString = reader.ReadToEnd();
  364. ret = srcString; //返回值赋值
  365. reader.Close();
  366. function.WriteLog(srcString, "请求开店宝API日志");
  367. }
  368. catch (Exception ex)
  369. {
  370. ret = "fail";
  371. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  372. }
  373. return ret;
  374. }
  375. #endregion
  376. }
  377. }