SetDepositService.cs 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431
  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. 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://sp.kexiaoshuang.com/api/test/SetDeposit?merNo=" + merchant.KqMerNo + "&sn=" + pos.PosSn + "&fee=" + Fee);
  65. // JsonData obj = JsonMapper.ToObject(content);
  66. // if (obj["code"].ToString() == "000000")
  67. // {
  68. // content = Decrypt(obj["data"].ToString());
  69. // function.WriteLog(content + "\n\n", "设置金控机具费率");
  70. // JsonData contentObj = JsonMapper.ToObject(content);
  71. // if (contentObj["respCode"].ToString() == "00")
  72. // {
  73. if(Kind == 1)
  74. {
  75. pos.UpFeeFlag = 1;
  76. pos.UpFeeMan = OpMan;
  77. pos.UpFeeDate = DateTime.Now;
  78. merchant.Status = 1;
  79. merchant.SeoKeyword = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  80. }
  81. else if(Kind == 2)
  82. {
  83. pos.DownFeeFlag = 1;
  84. pos.DownFeeMan = OpMan;
  85. pos.DownFeeDate = DateTime.Now;
  86. merchant.Status = 0;
  87. merchant.SeoKeyword = "";
  88. SetRecordResult(db, RecordId, 1);
  89. }
  90. db.SaveChanges();
  91. pos.QueryCount = Kind;
  92. if(userPosList.ContainsKey(pos.BuyUserId))
  93. {
  94. userPosList[pos.BuyUserId].Add(pos);
  95. }
  96. else
  97. {
  98. List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  99. subPos.Add(pos);
  100. userPosList.Add(pos.BuyUserId, subPos);
  101. }
  102. // }
  103. // else
  104. // {
  105. // string msg = contentObj["respMsg"].ToString();
  106. // pos.SeoDescription = msg;
  107. // SetRecordResult(db, RecordId, -1, msg);
  108. // db.SaveChanges();
  109. // }
  110. // }
  111. // else
  112. // {
  113. // string msg = obj["message"].ToString();
  114. // pos.SeoDescription = msg;
  115. // SetRecordResult(db, RecordId, -1, msg);
  116. // db.SaveChanges();
  117. // }
  118. // }
  119. // else if(pos.BrandId == 6) //立刷
  120. // {
  121. // string content = SetLiSFee(pos.PosSn, Fee);
  122. // JsonData obj = JsonMapper.ToObject(content);
  123. // if (obj["ret_code"].ToString() == "00")
  124. // {
  125. // if(Kind == 1)
  126. // {
  127. // pos.UpFeeFlag = 1;
  128. // pos.UpFeeMan = OpMan;
  129. // pos.UpFeeDate = DateTime.Now;
  130. // }
  131. // else if(Kind == 2)
  132. // {
  133. // pos.DownFeeFlag = 1;
  134. // pos.DownFeeMan = OpMan;
  135. // pos.DownFeeDate = DateTime.Now;
  136. // SetRecordResult(db, RecordId, 1);
  137. // }
  138. // db.SaveChanges();
  139. // pos.QueryCount = Kind;
  140. // if(userPosList.ContainsKey(pos.BuyUserId))
  141. // {
  142. // userPosList[pos.BuyUserId].Add(pos);
  143. // }
  144. // else
  145. // {
  146. // List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  147. // subPos.Add(pos);
  148. // userPosList.Add(pos.BuyUserId, subPos);
  149. // }
  150. // }
  151. // else
  152. // {
  153. // string msg = obj["ret_msg"].ToString();
  154. // pos.SeoDescription = msg;
  155. // SetRecordResult(db, RecordId, -1, msg);
  156. // db.SaveChanges();
  157. // }
  158. // }
  159. }
  160. }
  161. foreach(int UserId in userPosList.Keys)
  162. {
  163. string snhtml = "", snhtml2 = "";
  164. foreach (var items in userPosList[UserId])
  165. {
  166. var mer = merchantlist.FirstOrDefault(m => m.Id == items.BindMerchantId) ?? new PosMerchantInfo();
  167. var brand = brands.FirstOrDefault(m => m.Id == items.BrandId) ?? new KqProducts();
  168. if(items.QueryCount == 1)
  169. {
  170. snhtml += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  171. snhtml += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  172. snhtml += "<div class='f12'>SN:" + items.PosSn + "</div>";
  173. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  174. }
  175. else if(items.QueryCount == 2)
  176. {
  177. snhtml2 += "<div style='margin-bottom: .48rem;'><div class='f12'>商户姓名:" + mer.MerRealName + "</div>";
  178. snhtml2 += "<div class='f12'>机具品牌:" + brand.Name + "</div>";
  179. snhtml2 += "<div class='f12'>SN:" + items.PosSn + "</div>";
  180. string DownFeeDate = items.DownFeeDate == null ? "" : items.DownFeeDate.Value.ToString("yyyy-MM-dd HH:mm:ss");
  181. snhtml2 += "<div class='f12'>当前费率:0.6%</div>";
  182. snhtml2 += "<div class='f12'>费率调整时间:" + DownFeeDate + "</div>";
  183. }
  184. }
  185. if(!string.IsNullOrEmpty(snhtml))
  186. {
  187. snhtml = "<div style='margin-bottom: .48rem;'>" + snhtml + "</div>";
  188. RedisDbconn.Instance.AddList("MsgPersonalQueue", Newtonsoft.Json.JsonConvert.SerializeObject(new MsgPersonal()
  189. {
  190. UserId = Convert.ToInt32(UserId), //创客
  191. Title = "商户费率变更通知", //标题
  192. Content = "<div class='f12' style='margin-bottom: .72rem'>您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率</div>" + snhtml, //内容
  193. Summary = "您的部分机具已绑定超过180天,刷卡费率已自动变更为0.63%,如需调整费率,请前往我的商户-商户详情中调整费率",
  194. CreateDate = DateTime.Now,
  195. }));
  196. }
  197. else if(!string.IsNullOrEmpty(snhtml2))
  198. {
  199. snhtml2 = "<div style='margin-bottom: .48rem;'>" + snhtml2 + "</div>";
  200. RedisDbconn.Instance.AddList("MsgPersonalQueue", Newtonsoft.Json.JsonConvert.SerializeObject(new MsgPersonal()
  201. {
  202. UserId = Convert.ToInt32(UserId), //创客
  203. Title = "商户费率变更通知", //标题
  204. Content = "<div class='f12' style='margin-bottom: .72rem'>您的商户刷卡交易费率已变更成功!</div>" + snhtml2, //内容
  205. Summary = "您的商户刷卡交易费率已变更成功!",
  206. CreateDate = DateTime.Now,
  207. }));
  208. }
  209. }
  210. }
  211. db.Dispose();
  212. }
  213. catch (Exception ex)
  214. {
  215. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "设置费率队列异常");
  216. }
  217. }
  218. else
  219. {
  220. Thread.Sleep(60000);
  221. }
  222. }
  223. }
  224. private void SetRecordResult(WebCMSEntities db, int RecordId, int Status, string Note = "")
  225. {
  226. if(RecordId > 0)
  227. {
  228. PosMachinesFeeChangeRecord record = db.PosMachinesFeeChangeRecord.FirstOrDefault(m => m.Id == RecordId);
  229. if(record != null)
  230. {
  231. record.Status = Status;
  232. record.SeoDescription = Note;
  233. }
  234. }
  235. }
  236. #region 金控
  237. // 开发环境
  238. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  239. // 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";
  240. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  241. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  242. // string reqUrl = "https://test-push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  243. // 生产环境
  244. string merchantNo = "4487378308096";
  245. string clientId = "1243966544896";
  246. string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
  247. string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
  248. 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=";
  249. string reqUrl = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  250. public string SetJkFee(string merNo, string sn, decimal fee = 0.6M)
  251. {
  252. List<SetDepositList> rateDOs = new List<SetDepositList>();
  253. rateDOs.Add(new SetDepositList()
  254. {
  255. productSubType = "2020032007vz7Ux6",
  256. updateValue = fee,
  257. updateType = 0
  258. });
  259. Dictionary<string, string> headers = new Dictionary<string, string>();
  260. headers.Add("X-Client-ID", clientId);
  261. headers.Add("X-Security", "RSA");
  262. Dictionary<string, object> obj = new Dictionary<string, object>();
  263. obj.Add("merNo", merNo);
  264. obj.Add("sn", sn);
  265. obj.Add("batchUpdateType", 2);
  266. obj.Add("rateDOs", rateDOs);
  267. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  268. function.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  269. function.WriteLog(content, "设置金控机具费率");
  270. content = Encrypt(content);
  271. string signstr = Sign(content);
  272. headers.Add("X-Sign", signstr);
  273. string req = "{\"param\":\"" + content + "\"}";
  274. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  275. function.WriteLog(result, "设置金控机具费率");
  276. return result;
  277. }
  278. public string Decrypt(string data)
  279. {
  280. var toDecryptArray = Convert.FromBase64String(data);
  281. var rsa = RSA.Create();
  282. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  283. string result = "";
  284. List<byte> cache = new List<byte>();
  285. for (int i = 0; i < toDecryptArray.Length; i++)
  286. {
  287. cache.Add(toDecryptArray[i]);
  288. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  289. {
  290. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  291. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  292. cache.Clear();
  293. }
  294. }
  295. return result;
  296. }
  297. public string Encrypt(string data)
  298. {
  299. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  300. }
  301. public string Sign(string data)
  302. {
  303. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  304. var rsa = RSA.Create();
  305. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  306. string result = "";
  307. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  308. result = Convert.ToBase64String(buffer);
  309. return result;
  310. }
  311. #endregion
  312. #region 立刷
  313. string LiSAgentId = "50814834";
  314. string LiSPrivateKey = "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";
  315. string LiSReqUrl = "https://openapi.jlpay.com/access/charge/"; //请求url
  316. public string LiSSign(string data)
  317. {
  318. var rsa = RSA.Create();
  319. var key = Convert.FromBase64String(LiSPrivateKey);
  320. var content = Encoding.UTF8.GetBytes(data);
  321. rsa.ImportPkcs8PrivateKey(key, out _);
  322. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  323. return Convert.ToBase64String(result);
  324. }
  325. // 设置费率
  326. public string SetLiSFee(string sn, decimal serviceFee = 0.6M)
  327. {
  328. Dictionary<string, object> dic = new Dictionary<string, object>();
  329. dic.Add("agentId", LiSAgentId);
  330. dic.Add("deviceSn", sn);
  331. List<Dictionary<string, object>> feeList = new List<Dictionary<string, object>>();
  332. Dictionary<string, object> item = new Dictionary<string, object>();
  333. item.Add("feeCalcType", "M5");
  334. item.Add("fixed", "0");
  335. item.Add("rate", serviceFee);
  336. feeList.Add(item);
  337. dic.Add("feeList", feeList);
  338. dic.Add("signMethod", "02");
  339. string content = LiSAgentId + sn + "M50" + serviceFee + "02";
  340. string signstr = LiSSign(content);
  341. dic.Add("signData", signstr);
  342. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  343. function.WriteLog(DateTime.Now.ToString(), "设置立刷费率");
  344. function.WriteLog(req, "设置立刷费率");
  345. string result = PostWebRequest(LiSReqUrl + "FEE003", req, new Dictionary<string, string>());
  346. function.WriteLog(result, "设置立刷费率");
  347. function.WriteLog("\n\n", "设置立刷费率");
  348. return result;
  349. }
  350. public string QueryLiSDeposit(string merchNo, string sn)
  351. {
  352. Dictionary<string, object> dic = new Dictionary<string, object>();
  353. dic.Add("agentId", LiSAgentId);
  354. dic.Add("deviceSn", sn);
  355. dic.Add("merchNo", merchNo);
  356. dic.Add("signMethod", "02");
  357. string content = LiSAgentId + sn + merchNo + "02";
  358. string signstr = LiSSign(content);
  359. dic.Add("signData", signstr);
  360. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  361. string result = PostWebRequest(LiSReqUrl + "FEE001", req, new Dictionary<string, string>());
  362. return result;
  363. }
  364. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  365. {
  366. string ret = string.Empty;
  367. try
  368. {
  369. function.WriteLog(DateTime.Now.ToString(), "请求开店宝API日志");
  370. function.WriteLog(postUrl, "请求开店宝API日志");
  371. function.WriteLog(paramData, "请求开店宝API日志");
  372. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  373. // 设置提交的相关参数
  374. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  375. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  376. request.Method = "POST";
  377. request.KeepAlive = false;
  378. request.AllowAutoRedirect = true;
  379. request.ContentType = "application/json";
  380. foreach (string key in headers.Keys)
  381. {
  382. request.Headers.Add(key, headers[key]);
  383. }
  384. 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)";
  385. request.ContentLength = postData.Length;
  386. // 提交请求数据
  387. System.IO.Stream outputStream = request.GetRequestStream();
  388. outputStream.Write(postData, 0, postData.Length);
  389. outputStream.Close();
  390. System.Net.HttpWebResponse response;
  391. System.IO.Stream responseStream;
  392. System.IO.StreamReader reader;
  393. string srcString;
  394. response = request.GetResponse() as System.Net.HttpWebResponse;
  395. responseStream = response.GetResponseStream();
  396. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  397. srcString = reader.ReadToEnd();
  398. ret = srcString; //返回值赋值
  399. reader.Close();
  400. function.WriteLog(srcString, "请求开店宝API日志");
  401. }
  402. catch (Exception ex)
  403. {
  404. ret = "fail";
  405. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  406. }
  407. return ret;
  408. }
  409. #endregion
  410. }
  411. }