SetDepositPostService.cs 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530
  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(obj["code"].ToString() == "0000")
  97. {
  98. pos.SeoDescription = "设置成功";
  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. #region 金控
  180. // 开发环境
  181. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  182. // 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";
  183. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  184. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  185. // string reqUrl = "https://test-push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  186. // 生产环境
  187. string merchantNo = "4487378308096";
  188. string clientId = "1243966544896";
  189. string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
  190. string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
  191. 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=";
  192. string reqUrl = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  193. public string SetJkFee(string merNo, string sn, decimal fee = 0.6M)
  194. {
  195. List<SetDepositList> rateDOs = new List<SetDepositList>();
  196. rateDOs.Add(new SetDepositList()
  197. {
  198. productSubType = "2020032007vz7Ux6",
  199. updateValue = fee,
  200. updateType = 0
  201. });
  202. Dictionary<string, string> headers = new Dictionary<string, string>();
  203. headers.Add("X-Client-ID", clientId);
  204. headers.Add("X-Security", "RSA");
  205. Dictionary<string, object> obj = new Dictionary<string, object>();
  206. obj.Add("merNo", merNo);
  207. obj.Add("sn", sn);
  208. obj.Add("batchUpdateType", 2);
  209. obj.Add("rateDOs", rateDOs);
  210. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  211. function.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  212. function.WriteLog(content, "设置金控机具费率");
  213. content = Encrypt(content);
  214. string signstr = Sign(content);
  215. headers.Add("X-Sign", signstr);
  216. string req = "{\"param\":\"" + content + "\"}";
  217. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  218. function.WriteLog(result, "设置金控机具费率");
  219. return result;
  220. }
  221. public string Decrypt(string data)
  222. {
  223. var toDecryptArray = Convert.FromBase64String(data);
  224. var rsa = RSA.Create();
  225. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  226. string result = "";
  227. List<byte> cache = new List<byte>();
  228. for (int i = 0; i < toDecryptArray.Length; i++)
  229. {
  230. cache.Add(toDecryptArray[i]);
  231. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  232. {
  233. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  234. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  235. cache.Clear();
  236. }
  237. }
  238. return result;
  239. }
  240. public string Encrypt(string data)
  241. {
  242. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  243. }
  244. public string Sign(string data)
  245. {
  246. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  247. var rsa = RSA.Create();
  248. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  249. string result = "";
  250. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  251. result = Convert.ToBase64String(buffer);
  252. return result;
  253. }
  254. #endregion
  255. #region 开店宝
  256. //生产环境
  257. // string KdbApiUrl = "https://kzy.kdb-tj.com:5055/api";
  258. // string KDBAESKEY = "F@xh#sga41c08@pe";
  259. // string Kdb_Rsa_PrivateKey = "MIIBUwIBADANBgkqhkiG9w0BAQEFAASCAT0wggE5AgEAAkEAl2x9dSSCfNDik6VM2dn/SK1ONSbb7AKyXM1gHw8PMbzWN1pK7YGaPqHlIRbAeFeIvLKVeMxrji+63W6LpB0yDQIDAQABAkAfpHUnCIUYDhJ65f0EPTDCgCyqoL8uN3YMPIKMmvoC22/i7AC6zf/bWk4JdratN+gvvnjGgHQff6HH5dOQ6sbFAiEAxPYSLADzIv374J8O+LluXIcgI5zXm4r4dMtKbCmmWSsCIQDE0BRKsBcBZ9NvJ9Km+m/d1hN9v5hFT842zrkUFJmVpwIgBdYc17z3d3P7QL613NzxzkAazbNaGDvX/O4BOI9LZJ0CICrZElHgXGHV9NYyWU45H7mwLbYmzEPqx/5uqySQB4/pAiBgKYv3RGnsZ8Zm1EKAJjUX7ehdteBgPSA/UgIDZQ4oyw==";
  260. // string AgencyId = "3013890129";
  261. //开发环境
  262. string KdbApiUrl = "https://kzy-test.kdb-tj.com:5056/api";
  263. string KDBAESKEY = "Ebn4N28MvEXEvPTA";
  264. string Kdb_Rsa_PrivateKey = "MIIBVQIBADANBgkqhkiG9w0BAQEFAASCAT8wggE7AgEAAkEAsPyH5Y5NySHHKWIgPwxbZFkd33vzuWKv+Kdpug5/qYAnpTShDSMXQ2Ib7gc+B/yvj4uZ/k1A/xHpzHTPl6MzQQIDAQABAkA2sGHhyj45B2n+XKbwNIZNFMiJVUjzoQ4VPM4Lww0pt781GeqBCGgEIgTjmmg/FTGjgwTb7ta1A5G9Qn2nPG0RAiEA4x7W6XKdSL/FyVdlt4jijNQNZfLEqEPy1NnchRWUf40CIQDHfb49KP3pW4ZDX3xS42fYd9p7AGZ+qpVBnJfGGyFrhQIhALk3HCHyowuBwMUKLdw3mDEqeOarzO4/w1cLd8dcKua9AiEAtdPAj9JLDGWljMb9dDddsYockzwcL5ufizwFgkW8QlkCIADYU4+fFKqySLGX3MmEIJ/mU632PRtJAh4LSL8/Ij1H";
  265. string AgencyId = "3013890202";
  266. // 查询机构政策列表
  267. public string GetPolicyList()
  268. {
  269. string url = KdbApiUrl + "/marketing/plan/query/list";
  270. //[{"id":100014,"name":"韩测试营销方案(韩测试营销方案)"}]
  271. return PostKDB(url, "{}");
  272. }
  273. // 修改费率接口
  274. public string ModifyFee(string PosSn, decimal Fee)
  275. {
  276. string url = KdbApiUrl + "/pos/rate/modify/single/remote";
  277. string content = "{\"posSn\":\"" + PosSn + "\",\"type\":\"贷记卡刷卡\",\"rate\":\"" + Fee + "\",\"d0Fee\":\"0\"}";
  278. return PostKDB(url, content);
  279. }
  280. // 查询费率接口
  281. public string QueryFee(string orderNo)
  282. {
  283. string url = KdbApiUrl + "/pos/rate/change/query/orderno";
  284. string content = "{\"orderNo\":\"" + orderNo + "\"}";
  285. return PostKDB(url, content);
  286. }
  287. public string KDBDecrypt(string data)
  288. {
  289. string result = AesDecrypt(data, KDBAESKEY);
  290. return result;
  291. }
  292. public string AesDecrypt(string str, string key)
  293. {
  294. if (string.IsNullOrEmpty(str)) return null;
  295. byte[] toEncryptArray = Convert.FromBase64String(str);
  296. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  297. {
  298. Key = Encoding.UTF8.GetBytes(key),
  299. Mode = System.Security.Cryptography.CipherMode.ECB,
  300. Padding = System.Security.Cryptography.PaddingMode.PKCS7,
  301. };
  302. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
  303. byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  304. return Encoding.UTF8.GetString(resultArray);
  305. }
  306. public string AesEncrypt(string str)
  307. {
  308. // if (string.IsNullOrEmpty(str)) return null;
  309. Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
  310. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  311. {
  312. Key = Encoding.UTF8.GetBytes(KDBAESKEY),
  313. Mode = System.Security.Cryptography.CipherMode.ECB,
  314. Padding = System.Security.Cryptography.PaddingMode.PKCS7
  315. };
  316. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
  317. Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  318. return Convert.ToBase64String(resultArray);
  319. }
  320. public string PostKDB(string url, string content)
  321. {
  322. content = AesEncrypt(content);
  323. string timestamp = function.GetCurTimestamp().ToString();
  324. string sign = KDBSign(content + timestamp);
  325. string req = "{\"agencyId\":\"" + AgencyId + "\",\"content\":\"" + content + "\",\"timestamp\":\"" + timestamp + "\",\"sign\":\"" + sign + "\"}";
  326. string result = PostWebRequestKdb(url, req, new Dictionary<string, string>());
  327. return result;
  328. }
  329. private string PostWebRequestKdb(string postUrl, string paramData, Dictionary<string, string> headers)
  330. {
  331. string ret = string.Empty;
  332. try
  333. {
  334. function.WriteLog(DateTime.Now.ToString(), "请求开店宝API日志");
  335. function.WriteLog(postUrl, "请求开店宝API日志");
  336. function.WriteLog(paramData, "请求开店宝API日志");
  337. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  338. // 设置提交的相关参数
  339. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  340. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  341. request.Method = "POST";
  342. request.KeepAlive = false;
  343. request.AllowAutoRedirect = true;
  344. request.ContentType = "application/json";
  345. foreach (string key in headers.Keys)
  346. {
  347. request.Headers.Add(key, headers[key]);
  348. }
  349. 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)";
  350. request.ContentLength = postData.Length;
  351. // 提交请求数据
  352. System.IO.Stream outputStream = request.GetRequestStream();
  353. outputStream.Write(postData, 0, postData.Length);
  354. outputStream.Close();
  355. System.Net.HttpWebResponse response;
  356. System.IO.Stream responseStream;
  357. System.IO.StreamReader reader;
  358. string srcString;
  359. response = request.GetResponse() as System.Net.HttpWebResponse;
  360. responseStream = response.GetResponseStream();
  361. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  362. srcString = reader.ReadToEnd();
  363. ret = srcString; //返回值赋值
  364. reader.Close();
  365. function.WriteLog(srcString, "请求开店宝API日志");
  366. }
  367. catch (System.Net.WebException ex)
  368. {
  369. System.Net.HttpWebResponse response = (System.Net.HttpWebResponse)ex.Response;
  370. System.IO.Stream myResponseStream = response.GetResponseStream();
  371. //获取响应内容
  372. System.IO.StreamReader myStreamReader = new System.IO.StreamReader(myResponseStream);
  373. ret = myStreamReader.ReadToEnd();
  374. myResponseStream.Close();
  375. }
  376. catch (Exception ex)
  377. {
  378. ret = "fail";
  379. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  380. }
  381. return ret;
  382. }
  383. public string KDBSign(string data)
  384. {
  385. var rsa = RSA.Create();
  386. var key = Convert.FromBase64String(Kdb_Rsa_PrivateKey);
  387. var content = Encoding.UTF8.GetBytes(data);
  388. rsa.ImportPkcs8PrivateKey(key, out _);
  389. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  390. return Convert.ToBase64String(result);
  391. }
  392. #endregion
  393. #region 立刷
  394. string LiSAgentId = "50814834";
  395. string LiSPrivateKey = "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";
  396. string LiSReqUrl = "https://openapi.jlpay.com/access/charge/"; //请求url
  397. public string LiSSign(string data)
  398. {
  399. var rsa = RSA.Create();
  400. var key = Convert.FromBase64String(LiSPrivateKey);
  401. var content = Encoding.UTF8.GetBytes(data);
  402. rsa.ImportPkcs8PrivateKey(key, out _);
  403. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  404. return Convert.ToBase64String(result);
  405. }
  406. // 设置费率
  407. public string SetLiSFee(string sn, decimal serviceFee = 0.6M)
  408. {
  409. Dictionary<string, object> dic = new Dictionary<string, object>();
  410. dic.Add("agentId", LiSAgentId);
  411. dic.Add("deviceSn", sn);
  412. List<Dictionary<string, object>> feeList = new List<Dictionary<string, object>>();
  413. Dictionary<string, object> item = new Dictionary<string, object>();
  414. item.Add("feeCalcType", "M5");
  415. item.Add("fixed", "0");
  416. item.Add("rate", serviceFee);
  417. feeList.Add(item);
  418. dic.Add("feeList", feeList);
  419. dic.Add("signMethod", "02");
  420. string content = LiSAgentId + sn + "M50" + serviceFee + "02";
  421. string signstr = LiSSign(content);
  422. dic.Add("signData", signstr);
  423. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  424. function.WriteLog(DateTime.Now.ToString(), "设置立刷费率");
  425. function.WriteLog(req, "设置立刷费率");
  426. string result = PostWebRequest(LiSReqUrl + "FEE003", req, new Dictionary<string, string>());
  427. function.WriteLog(result, "设置立刷费率");
  428. function.WriteLog("\n\n", "设置立刷费率");
  429. return result;
  430. }
  431. public string QueryLiSDeposit(string merchNo, string sn)
  432. {
  433. Dictionary<string, object> dic = new Dictionary<string, object>();
  434. dic.Add("agentId", LiSAgentId);
  435. dic.Add("deviceSn", sn);
  436. dic.Add("merchNo", merchNo);
  437. dic.Add("signMethod", "02");
  438. string content = LiSAgentId + sn + merchNo + "02";
  439. string signstr = LiSSign(content);
  440. dic.Add("signData", signstr);
  441. string req = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
  442. string result = PostWebRequest(LiSReqUrl + "FEE001", req, new Dictionary<string, string>());
  443. return result;
  444. }
  445. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  446. {
  447. string ret = string.Empty;
  448. try
  449. {
  450. function.WriteLog(DateTime.Now.ToString(), "请求立刷API日志");
  451. function.WriteLog(postUrl, "请求立刷API日志");
  452. function.WriteLog(paramData, "请求立刷API日志");
  453. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  454. // 设置提交的相关参数
  455. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  456. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  457. request.Method = "POST";
  458. request.KeepAlive = false;
  459. request.AllowAutoRedirect = true;
  460. request.ContentType = "application/json";
  461. foreach (string key in headers.Keys)
  462. {
  463. request.Headers.Add(key, headers[key]);
  464. }
  465. 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)";
  466. request.ContentLength = postData.Length;
  467. // 提交请求数据
  468. System.IO.Stream outputStream = request.GetRequestStream();
  469. outputStream.Write(postData, 0, postData.Length);
  470. outputStream.Close();
  471. System.Net.HttpWebResponse response;
  472. System.IO.Stream responseStream;
  473. System.IO.StreamReader reader;
  474. string srcString;
  475. response = request.GetResponse() as System.Net.HttpWebResponse;
  476. responseStream = response.GetResponseStream();
  477. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  478. srcString = reader.ReadToEnd();
  479. ret = srcString; //返回值赋值
  480. reader.Close();
  481. function.WriteLog(srcString, "请求立刷API日志");
  482. }
  483. catch (Exception ex)
  484. {
  485. ret = "fail";
  486. function.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求立刷API异常");
  487. }
  488. return ret;
  489. }
  490. #endregion
  491. }
  492. }