SetDepositPostService.cs 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  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. foreach(PosMachinesTwo pos in poslist)
  56. {
  57. PosMerchantInfo merchant = merchantlist.FirstOrDefault(m => m.Id == pos.BindMerchantId);
  58. if(merchant != null)
  59. {
  60. decimal Fee = Kind == 1 ? 0.63M : 0.6M;
  61. if(pos.BrandId == 1 || pos.BrandId == 3) //金控
  62. {
  63. string content = function.GetWebRequest("http://connect.kexiaoshuang.com/home/setfee?merNo=" + merchant.KqMerNo + "&sn=" + pos.PosSn + "&fee=" + Fee);
  64. if(content.Contains("|"))
  65. {
  66. content = content.Split("|")[1];
  67. JsonData obj = JsonMapper.ToObject(content);
  68. if(obj["errorCode"].ToString() == "0000")
  69. {
  70. pos.SeoDescription = "设置成功";
  71. SetRecordResult(db, RecordId, 1, "设置成功");
  72. db.SaveChanges();
  73. }
  74. else
  75. {
  76. string msg = obj["errorCodeDesc"].ToString();
  77. pos.SeoDescription = msg;
  78. SetRecordResult(db, RecordId, -1, msg);
  79. db.SaveChanges();
  80. }
  81. }
  82. else
  83. {
  84. JsonData obj = JsonMapper.ToObject(content);
  85. string msg = obj["message"].ToString();
  86. pos.SeoDescription = msg;
  87. SetRecordResult(db, RecordId, -1, msg);
  88. db.SaveChanges();
  89. }
  90. }
  91. else if(pos.BrandId == 2) //开店宝
  92. {
  93. Fee = Fee / 100;
  94. string content = ModifyFee(pos.PosSn, Fee);
  95. JsonData obj = JsonMapper.ToObject(content);
  96. if(content.Contains("orderNo"))
  97. {
  98. pos.SeoDescription = "提交成功|" + obj["orderNo"].ToString() + "|" + RecordId;
  99. // SetRecordResult(db, RecordId, 1, "设置成功");
  100. db.SaveChanges();
  101. }
  102. else
  103. {
  104. string msg = obj["msg"].ToString();
  105. pos.SeoDescription = msg;
  106. SetRecordResult(db, RecordId, -1, msg);
  107. db.SaveChanges();
  108. }
  109. }
  110. // else if(pos.BrandId == 6) //立刷
  111. // {
  112. // string content = SetLiSFee(pos.PosSn, Fee);
  113. // JsonData obj = JsonMapper.ToObject(content);
  114. // if (obj["ret_code"].ToString() == "00")
  115. // {
  116. // if(Kind == 1)
  117. // {
  118. // pos.UpFeeFlag = 1;
  119. // pos.UpFeeMan = OpMan;
  120. // pos.UpFeeDate = DateTime.Now;
  121. // }
  122. // else if(Kind == 2)
  123. // {
  124. // pos.DownFeeFlag = 1;
  125. // pos.DownFeeMan = OpMan;
  126. // pos.DownFeeDate = DateTime.Now;
  127. // SetRecordResult(db, RecordId, 1);
  128. // }
  129. // db.SaveChanges();
  130. // pos.QueryCount = Kind;
  131. // if(userPosList.ContainsKey(pos.BuyUserId))
  132. // {
  133. // userPosList[pos.BuyUserId].Add(pos);
  134. // }
  135. // else
  136. // {
  137. // List<PosMachinesTwo> subPos = new List<PosMachinesTwo>();
  138. // subPos.Add(pos);
  139. // userPosList.Add(pos.BuyUserId, subPos);
  140. // }
  141. // }
  142. // else
  143. // {
  144. // string msg = obj["ret_msg"].ToString();
  145. // pos.SeoDescription = msg;
  146. // SetRecordResult(db, RecordId, -1, msg);
  147. // db.SaveChanges();
  148. // }
  149. // }
  150. }
  151. }
  152. }
  153. db.Dispose();
  154. Thread.Sleep(500);
  155. }
  156. catch (Exception ex)
  157. {
  158. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "设置费率到支付平台异常");
  159. }
  160. }
  161. else
  162. {
  163. Thread.Sleep(60000);
  164. }
  165. }
  166. }
  167. private void SetRecordResult(WebCMSEntities db, int RecordId, int Status, string Note = "")
  168. {
  169. if(RecordId > 0)
  170. {
  171. PosMachinesFeeChangeRecord record = db.PosMachinesFeeChangeRecord.FirstOrDefault(m => m.Id == RecordId);
  172. if(record != null)
  173. {
  174. record.Status = Status;
  175. record.SeoDescription = Note;
  176. }
  177. }
  178. }
  179. public void StartKdb()
  180. {
  181. Thread th = new Thread(StartKdbDo);
  182. th.IsBackground = true;
  183. th.Start();
  184. }
  185. private void StartKdbDo()
  186. {
  187. while (true)
  188. {
  189. try
  190. {
  191. WebCMSEntities db = new WebCMSEntities();
  192. var poslist = db.PosMachinesTwo.Select(m => new { m.Id, m.BrandId, m.SeoDescription }).Where(m => m.BrandId == 2 && m.SeoDescription.StartsWith("提交成功|")).ToList();
  193. foreach (var pos in poslist)
  194. {
  195. string[] datalist = pos.SeoDescription.Split('|');
  196. string orderNo = datalist[1];
  197. int RecordId = int.Parse(datalist[2]);
  198. string content = QueryFee(orderNo);
  199. JsonData obj = JsonMapper.ToObject(content);
  200. PosMachinesTwo edit = db.PosMachinesTwo.FirstOrDefault(m => m.Id == pos.Id);
  201. if(edit != null)
  202. {
  203. if(obj["status"].ToString() == "HANDLE_STATUS_COMPLETE")
  204. {
  205. edit.SeoDescription = "设置成功";
  206. SetRecordResult(db, RecordId, 1, "设置成功");
  207. db.SaveChanges();
  208. }
  209. else
  210. {
  211. edit.SeoDescription = "设置失败";
  212. SetRecordResult(db, RecordId, -1, "设置失败");
  213. db.SaveChanges();
  214. }
  215. }
  216. }
  217. db.Dispose();
  218. }
  219. catch(Exception ex)
  220. {
  221. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "开店宝费率异步获取结果异常");
  222. }
  223. Thread.Sleep(5000);
  224. }
  225. }
  226. #region 金控
  227. // 开发环境
  228. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  229. // 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";
  230. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  231. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  232. // string reqUrl = "https://test-push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  233. // 生产环境
  234. string merchantNo = "4487378308096";
  235. string clientId = "1243966544896";
  236. string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
  237. string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
  238. 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=";
  239. string reqUrl = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  240. public string SetJkFee(string merNo, string sn, decimal fee = 0.6M)
  241. {
  242. List<SetDepositList> rateDOs = new List<SetDepositList>();
  243. rateDOs.Add(new SetDepositList()
  244. {
  245. productSubType = "2020032007vz7Ux6",
  246. updateValue = fee,
  247. updateType = 0
  248. });
  249. Dictionary<string, string> headers = new Dictionary<string, string>();
  250. headers.Add("X-Client-ID", clientId);
  251. headers.Add("X-Security", "RSA");
  252. Dictionary<string, object> obj = new Dictionary<string, object>();
  253. obj.Add("merNo", merNo);
  254. obj.Add("sn", sn);
  255. obj.Add("batchUpdateType", 2);
  256. obj.Add("rateDOs", rateDOs);
  257. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  258. function.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  259. function.WriteLog(content, "设置金控机具费率");
  260. content = Encrypt(content);
  261. string signstr = Sign(content);
  262. headers.Add("X-Sign", signstr);
  263. string req = "{\"param\":\"" + content + "\"}";
  264. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  265. function.WriteLog(result, "设置金控机具费率");
  266. return result;
  267. }
  268. public string Decrypt(string data)
  269. {
  270. var toDecryptArray = Convert.FromBase64String(data);
  271. var rsa = RSA.Create();
  272. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  273. string result = "";
  274. List<byte> cache = new List<byte>();
  275. for (int i = 0; i < toDecryptArray.Length; i++)
  276. {
  277. cache.Add(toDecryptArray[i]);
  278. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  279. {
  280. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  281. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  282. cache.Clear();
  283. }
  284. }
  285. return result;
  286. }
  287. public string Encrypt(string data)
  288. {
  289. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  290. }
  291. public string Sign(string data)
  292. {
  293. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  294. var rsa = RSA.Create();
  295. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  296. string result = "";
  297. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  298. result = Convert.ToBase64String(buffer);
  299. return result;
  300. }
  301. #endregion
  302. #region 开店宝
  303. //生产环境
  304. string KdbApiUrl = "https://kzy.kdb-tj.com:5055/api";
  305. string KDBAESKEY = "F@xh#sga41c08@pe";
  306. string Kdb_Rsa_PrivateKey = "MIIBUwIBADANBgkqhkiG9w0BAQEFAASCAT0wggE5AgEAAkEAl2x9dSSCfNDik6VM2dn/SK1ONSbb7AKyXM1gHw8PMbzWN1pK7YGaPqHlIRbAeFeIvLKVeMxrji+63W6LpB0yDQIDAQABAkAfpHUnCIUYDhJ65f0EPTDCgCyqoL8uN3YMPIKMmvoC22/i7AC6zf/bWk4JdratN+gvvnjGgHQff6HH5dOQ6sbFAiEAxPYSLADzIv374J8O+LluXIcgI5zXm4r4dMtKbCmmWSsCIQDE0BRKsBcBZ9NvJ9Km+m/d1hN9v5hFT842zrkUFJmVpwIgBdYc17z3d3P7QL613NzxzkAazbNaGDvX/O4BOI9LZJ0CICrZElHgXGHV9NYyWU45H7mwLbYmzEPqx/5uqySQB4/pAiBgKYv3RGnsZ8Zm1EKAJjUX7ehdteBgPSA/UgIDZQ4oyw==";
  307. string AgencyId = "3013890129";
  308. //开发环境
  309. // string KdbApiUrl = "https://kzy-test.kdb-tj.com:5056/api";
  310. // string KDBAESKEY = "Ebn4N28MvEXEvPTA";
  311. // string Kdb_Rsa_PrivateKey = "MIIBVQIBADANBgkqhkiG9w0BAQEFAASCAT8wggE7AgEAAkEAsPyH5Y5NySHHKWIgPwxbZFkd33vzuWKv+Kdpug5/qYAnpTShDSMXQ2Ib7gc+B/yvj4uZ/k1A/xHpzHTPl6MzQQIDAQABAkA2sGHhyj45B2n+XKbwNIZNFMiJVUjzoQ4VPM4Lww0pt781GeqBCGgEIgTjmmg/FTGjgwTb7ta1A5G9Qn2nPG0RAiEA4x7W6XKdSL/FyVdlt4jijNQNZfLEqEPy1NnchRWUf40CIQDHfb49KP3pW4ZDX3xS42fYd9p7AGZ+qpVBnJfGGyFrhQIhALk3HCHyowuBwMUKLdw3mDEqeOarzO4/w1cLd8dcKua9AiEAtdPAj9JLDGWljMb9dDddsYockzwcL5ufizwFgkW8QlkCIADYU4+fFKqySLGX3MmEIJ/mU632PRtJAh4LSL8/Ij1H";
  312. // string AgencyId = "3013890202";
  313. // 修改费率接口
  314. public string ModifyFee(string PosSn, decimal Fee)
  315. {
  316. string url = KdbApiUrl + "/pos/rate/modify/single/remote";
  317. string content = "{\"posSn\":\"" + PosSn + "\",\"type\":\"贷记卡刷卡\",\"rate\":\"" + Fee + "\",\"d0Fee\":\"0\"}";
  318. return PostKDB(url, content);
  319. }
  320. // 查询费率接口
  321. public string QueryFee(string orderNo)
  322. {
  323. string url = KdbApiUrl + "/pos/rate/change/query/orderno";
  324. string content = "{\"orderNo\":\"" + orderNo + "\"}";
  325. return PostKDB(url, content);
  326. }
  327. public string KDBDecrypt(string data)
  328. {
  329. string result = AesDecrypt(data, KDBAESKEY);
  330. return result;
  331. }
  332. public string AesDecrypt(string str, string key)
  333. {
  334. if (string.IsNullOrEmpty(str)) return null;
  335. byte[] toEncryptArray = Convert.FromBase64String(str);
  336. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  337. {
  338. Key = Encoding.UTF8.GetBytes(key),
  339. Mode = System.Security.Cryptography.CipherMode.ECB,
  340. Padding = System.Security.Cryptography.PaddingMode.PKCS7,
  341. };
  342. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
  343. byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  344. return Encoding.UTF8.GetString(resultArray);
  345. }
  346. public string AesEncrypt(string str)
  347. {
  348. // if (string.IsNullOrEmpty(str)) return null;
  349. Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
  350. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  351. {
  352. Key = Encoding.UTF8.GetBytes(KDBAESKEY),
  353. Mode = System.Security.Cryptography.CipherMode.ECB,
  354. Padding = System.Security.Cryptography.PaddingMode.PKCS7
  355. };
  356. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
  357. Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  358. return Convert.ToBase64String(resultArray);
  359. }
  360. public string PostKDB(string url, string content)
  361. {
  362. content = AesEncrypt(content);
  363. string timestamp = function.GetCurTimestamp().ToString();
  364. string sign = KDBSign(content + timestamp);
  365. string req = "{\"agencyId\":\"" + AgencyId + "\",\"content\":\"" + content + "\",\"timestamp\":\"" + timestamp + "\",\"sign\":\"" + sign + "\"}";
  366. string result = PostWebRequestKdb(url, req, new Dictionary<string, string>());
  367. return result;
  368. }
  369. private string PostWebRequestKdb(string postUrl, string paramData, Dictionary<string, string> headers)
  370. {
  371. string ret = string.Empty;
  372. try
  373. {
  374. function.WriteLog(DateTime.Now.ToString(), "请求开店宝API日志");
  375. function.WriteLog(postUrl, "请求开店宝API日志");
  376. function.WriteLog(paramData, "请求开店宝API日志");
  377. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  378. // 设置提交的相关参数
  379. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  380. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  381. request.Method = "POST";
  382. request.KeepAlive = false;
  383. request.AllowAutoRedirect = true;
  384. request.ContentType = "application/json";
  385. foreach (string key in headers.Keys)
  386. {
  387. request.Headers.Add(key, headers[key]);
  388. }
  389. 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)";
  390. request.ContentLength = postData.Length;
  391. // 提交请求数据
  392. System.IO.Stream outputStream = request.GetRequestStream();
  393. outputStream.Write(postData, 0, postData.Length);
  394. outputStream.Close();
  395. System.Net.HttpWebResponse response;
  396. System.IO.Stream responseStream;
  397. System.IO.StreamReader reader;
  398. string srcString;
  399. response = request.GetResponse() as System.Net.HttpWebResponse;
  400. responseStream = response.GetResponseStream();
  401. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  402. srcString = reader.ReadToEnd();
  403. ret = srcString; //返回值赋值
  404. reader.Close();
  405. function.WriteLog(srcString, "请求开店宝API日志");
  406. }
  407. catch (System.Net.WebException ex)
  408. {
  409. System.Net.HttpWebResponse response = (System.Net.HttpWebResponse)ex.Response;
  410. System.IO.Stream myResponseStream = response.GetResponseStream();
  411. //获取响应内容
  412. System.IO.StreamReader myStreamReader = new System.IO.StreamReader(myResponseStream);
  413. ret = myStreamReader.ReadToEnd();
  414. myResponseStream.Close();
  415. }
  416. catch (Exception ex)
  417. {
  418. ret = "fail";
  419. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  420. }
  421. return ret;
  422. }
  423. public string KDBSign(string data)
  424. {
  425. var rsa = RSA.Create();
  426. var key = Convert.FromBase64String(Kdb_Rsa_PrivateKey);
  427. var content = Encoding.UTF8.GetBytes(data);
  428. rsa.ImportPkcs8PrivateKey(key, out _);
  429. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  430. return Convert.ToBase64String(result);
  431. }
  432. #endregion
  433. #region 立刷
  434. string LiSAgentId = "50814834";
  435. string LiSPrivateKey = "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";
  436. string LiSReqUrl = "https://openapi.jlpay.com/access/charge/"; //请求url
  437. public string LiSSign(string data)
  438. {
  439. var rsa = RSA.Create();
  440. var key = Convert.FromBase64String(LiSPrivateKey);
  441. var content = Encoding.UTF8.GetBytes(data);
  442. rsa.ImportPkcs8PrivateKey(key, out _);
  443. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  444. return Convert.ToBase64String(result);
  445. }
  446. // 设置费率
  447. public string SetLiSFee(string sn, decimal serviceFee = 0.6M)
  448. {
  449. Dictionary<string, object> dic = new Dictionary<string, object>();
  450. dic.Add("agentId", LiSAgentId);
  451. dic.Add("deviceSn", sn);
  452. List<Dictionary<string, object>> feeList = new List<Dictionary<string, object>>();
  453. Dictionary<string, object> item = new Dictionary<string, object>();
  454. item.Add("feeCalcType", "M5");
  455. item.Add("fixed", "0");
  456. item.Add("rate", serviceFee);
  457. feeList.Add(item);
  458. dic.Add("feeList", feeList);
  459. dic.Add("signMethod", "02");
  460. string content = LiSAgentId + sn + "M50" + serviceFee + "02";
  461. string signstr = LiSSign(content);
  462. dic.Add("signData", signstr);
  463. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  464. function.WriteLog(DateTime.Now.ToString(), "设置立刷费率");
  465. function.WriteLog(req, "设置立刷费率");
  466. string result = PostWebRequest(LiSReqUrl + "FEE003", req, new Dictionary<string, string>());
  467. function.WriteLog(result, "设置立刷费率");
  468. function.WriteLog("\n\n", "设置立刷费率");
  469. return result;
  470. }
  471. public string QueryLiSDeposit(string merchNo, string sn)
  472. {
  473. Dictionary<string, object> dic = new Dictionary<string, object>();
  474. dic.Add("agentId", LiSAgentId);
  475. dic.Add("deviceSn", sn);
  476. dic.Add("merchNo", merchNo);
  477. dic.Add("signMethod", "02");
  478. string content = LiSAgentId + sn + merchNo + "02";
  479. string signstr = LiSSign(content);
  480. dic.Add("signData", signstr);
  481. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  482. string result = PostWebRequest(LiSReqUrl + "FEE001", req, new Dictionary<string, string>());
  483. return result;
  484. }
  485. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  486. {
  487. string ret = string.Empty;
  488. try
  489. {
  490. function.WriteLog(DateTime.Now.ToString(), "请求立刷API日志");
  491. function.WriteLog(postUrl, "请求立刷API日志");
  492. function.WriteLog(paramData, "请求立刷API日志");
  493. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  494. // 设置提交的相关参数
  495. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  496. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  497. request.Method = "POST";
  498. request.KeepAlive = false;
  499. request.AllowAutoRedirect = true;
  500. request.ContentType = "application/json";
  501. foreach (string key in headers.Keys)
  502. {
  503. request.Headers.Add(key, headers[key]);
  504. }
  505. 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)";
  506. request.ContentLength = postData.Length;
  507. // 提交请求数据
  508. System.IO.Stream outputStream = request.GetRequestStream();
  509. outputStream.Write(postData, 0, postData.Length);
  510. outputStream.Close();
  511. System.Net.HttpWebResponse response;
  512. System.IO.Stream responseStream;
  513. System.IO.StreamReader reader;
  514. string srcString;
  515. response = request.GetResponse() as System.Net.HttpWebResponse;
  516. responseStream = response.GetResponseStream();
  517. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  518. srcString = reader.ReadToEnd();
  519. ret = srcString; //返回值赋值
  520. reader.Close();
  521. function.WriteLog(srcString, "请求立刷API日志");
  522. }
  523. catch (Exception ex)
  524. {
  525. ret = "fail";
  526. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求立刷API异常");
  527. }
  528. return ret;
  529. }
  530. #endregion
  531. }
  532. }