PublicImportDataService.cs 75 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Security.Cryptography;
  5. using System.Web;
  6. using System.Linq;
  7. using System.Text.RegularExpressions;
  8. using MySystem.Models;
  9. using Library;
  10. using LitJson;
  11. using System.Security.Cryptography.X509Certificates;
  12. using Org.BouncyCastle.Security;
  13. using Org.BouncyCastle.Crypto.Parameters;
  14. using System.Text;
  15. using Org.BouncyCastle.Crypto;
  16. using Org.BouncyCastle.Math;
  17. using System.Net.Http;
  18. using System.Threading.Tasks;
  19. using System.Threading;
  20. namespace MySystem
  21. {
  22. public class PublicImportDataService
  23. {
  24. public readonly static PublicImportDataService Instance = new PublicImportDataService();
  25. private PublicImportDataService()
  26. { }
  27. public void Start(JobMqMsg jobInfo)
  28. {
  29. string data = "";
  30. try
  31. {
  32. string orderString = jobInfo.OrderString;
  33. if (!string.IsNullOrEmpty(orderString))
  34. {
  35. string key = orderString.Split(':')[1];
  36. int BrandId = int.Parse(function.CheckInt(key.Split('_')[3]));
  37. bool op = true;
  38. while (op)
  39. {
  40. try
  41. {
  42. data = RedisDbconn.Instance.RPop<string>(key);
  43. if (data != null)
  44. {
  45. string content = "";
  46. if (data.Contains("#cut#"))
  47. {
  48. string[] dataList = data.Replace("\r", "").Replace("\n", "").Split(new string[] { "#cut#" }, StringSplitOptions.None);
  49. JsonData jsonData = JsonMapper.ToObject(dataList[1]);
  50. if (BrandId == 1)
  51. {
  52. content = Decrypt(jsonData["param"].ToString());
  53. AppendLog(dataList[0], content, BrandId);
  54. InsertData(key, content, jobInfo, BrandId);
  55. }
  56. else if (BrandId == 27)
  57. {
  58. content = LkbDecrypt(jsonData["param"].ToString());
  59. AppendLog(dataList[0], content, BrandId);
  60. InsertData(key, content, jobInfo, BrandId);
  61. }
  62. else if (BrandId == 2)
  63. {
  64. content = KDBDecrypt(jsonData["content"].ToString());
  65. AppendLog(dataList[0], content, BrandId);
  66. if (content.StartsWith("[") && content.EndsWith("]"))
  67. {
  68. content = content.Replace("null", "\"\"");
  69. content = content.Replace("NULL", "\"\"");
  70. JsonData list = JsonMapper.ToObject(content);
  71. for (int i = 0; i < list.Count; i++)
  72. {
  73. InsertData(key, list[i].ToJson(), jobInfo, BrandId);
  74. }
  75. }
  76. else
  77. {
  78. InsertData(key, content, jobInfo, BrandId);
  79. }
  80. }
  81. else if (BrandId == 4)
  82. {
  83. content = LSDecrypt(jsonData["data"].ToString(), jsonData["sign"].ToString());
  84. AppendLog(dataList[0], content, BrandId);
  85. InsertData(key, content, jobInfo, BrandId);
  86. }
  87. else if (BrandId == 8 || BrandId == 9)
  88. {
  89. content = HKDecrypt(jsonData["data"].ToString(), jsonData["sign"].ToString(), BrandId);
  90. AppendLog(dataList[0], content, BrandId);
  91. InsertData(key, content, jobInfo, BrandId);
  92. }
  93. else if (BrandId == 10)
  94. {
  95. content = LDDecrypt(jsonData["data"].ToString());
  96. AppendLog(dataList[0], content, BrandId);
  97. InsertData(key, content, jobInfo, BrandId);
  98. }
  99. else if (BrandId == 34)
  100. {
  101. string aesKey = jsonData["encryptKey"].ToString();
  102. aesKey = LDZZBDecrypt(aesKey);
  103. content = AesDecrypt(jsonData["data"].ToString(), aesKey);
  104. AppendLog(dataList[0], content, BrandId);
  105. InsertData(key, content, jobInfo, BrandId);
  106. }
  107. else if (BrandId == 12)
  108. {
  109. content = dataList[1];
  110. JsonData header = JsonMapper.ToObject(dataList[0]);
  111. string signstr = header["X-Sign"][0].ToString();
  112. SortedList<string, string> dic = Newtonsoft.Json.JsonConvert.DeserializeObject<SortedList<string, string>>(content);
  113. string sign = function.BuildQueryString(dic);
  114. bool checkSign = BoxVerifySign(sign, signstr);
  115. if(checkSign)
  116. {
  117. AppendLog(dataList[0], content, BrandId);
  118. InsertData(key, content, jobInfo, BrandId);
  119. }
  120. }
  121. else if (BrandId == 15 || BrandId == 17)
  122. {
  123. content = PosPDecrypt(jsonData["content"].ToString(), jsonData["sign"].ToString());
  124. if(!string.IsNullOrEmpty(content))
  125. {
  126. AppendLog(dataList[0], content, BrandId);
  127. InsertData(key, content, jobInfo, BrandId);
  128. }
  129. }
  130. else if (BrandId == 30)
  131. {
  132. content = LklDecrypt(jsonData["data"].ToString());
  133. if(!string.IsNullOrEmpty(content))
  134. {
  135. AppendLog(dataList[0], content, BrandId);
  136. InsertData(key, content, jobInfo, BrandId);
  137. }
  138. }
  139. else
  140. {
  141. content = dataList[1];
  142. InsertData(key, content, jobInfo, BrandId);
  143. }
  144. if (dataList.Length > 2)
  145. {
  146. string fileName = dataList[2];
  147. if (System.IO.File.Exists(function.getPath("/redis/" + key + "/" + fileName + ".txt")))
  148. {
  149. System.IO.File.Delete(function.getPath("/redis/" + key + "/" + fileName + ".txt"));
  150. }
  151. }
  152. }
  153. }
  154. else
  155. {
  156. // op = false;
  157. Thread.Sleep(function.get_Random(3000, 5000));
  158. }
  159. }
  160. catch (Exception ex)
  161. {
  162. Utils.WriteLog(DateTime.Now.ToString() + "\n" + data + "\n" + ex.ToString(), key + "队列异常");
  163. Start(jobInfo);
  164. Thread.Sleep(60000);
  165. }
  166. }
  167. }
  168. }
  169. catch (Exception ex)
  170. {
  171. LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\n" + data + "\n" + ex.ToString(), "public_import_service");
  172. Start(jobInfo);
  173. }
  174. }
  175. private void AppendLog(string header, string content, int BrandId)
  176. {
  177. string BrandName = "";
  178. if (BrandId == 1)
  179. {
  180. BrandName = "金控";
  181. }
  182. else if (BrandId == 2)
  183. {
  184. BrandName = "开店宝";
  185. }
  186. else if (BrandId == 4)
  187. {
  188. BrandName = "乐刷";
  189. }
  190. else if (BrandId == 6)
  191. {
  192. BrandName = "立刷";
  193. }
  194. else if (BrandId == 22)
  195. {
  196. BrandName = "立刷微电签";
  197. }
  198. else if (BrandId == 8)
  199. {
  200. BrandName = "海科电签";
  201. }
  202. else if (BrandId == 9)
  203. {
  204. BrandName = "海科大POS";
  205. }
  206. else if (BrandId == 10)
  207. {
  208. BrandName = "联动电签";
  209. }
  210. else if (BrandId == 12)
  211. {
  212. BrandName = "盒易付";
  213. }
  214. else if (BrandId == 15)
  215. {
  216. BrandName = "联客宝";
  217. }
  218. else if (BrandId == 30)
  219. {
  220. BrandName = "拉卡拉";
  221. }
  222. else if (BrandId == 34)
  223. {
  224. BrandName = "联动掌中宝";
  225. }
  226. LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\r\n" + header + "\r\n" + content, BrandName + "推送消息");
  227. }
  228. public void InsertData(string key, string content, JobMqMsg jobInfo, int BrandId)
  229. {
  230. string Id = DoQueue(content, jobInfo.BrandInfo, BrandId);
  231. // 商户入库
  232. if (key.Contains("_changebind_"))
  233. {
  234. int IdNum = int.Parse(Id);
  235. WebCMSEntities db = new WebCMSEntities();
  236. BindRecord bind = db.BindRecord.FirstOrDefault(m => m.Id == IdNum);
  237. if (bind != null)
  238. {
  239. // string ProductType = BrandId.ToString();
  240. // bool check = db.Merchants.Any(m => m.MerNo == bind.MerNo && m.ProductType == ProductType);
  241. // if (!check)
  242. // {
  243. db.Merchants.Add(new Merchants()
  244. {
  245. CreateDate = DateTime.Now,
  246. UpdateDate = DateTime.Now,
  247. MerNo = bind.MerNo, //商户编号
  248. MerName = bind.MerName, //商户名称
  249. AgentName = bind.AgentName, //机构名称
  250. ProductType = BrandId.ToString(), //产品类型
  251. Remark = "商户入库", //注释
  252. CreateTime = DateTime.Now, //创建时间
  253. UpdateTime = DateTime.Now, //更新时间
  254. SnNo = bind.MerSnNo, //SN号
  255. MerMobile = bind.MerNewSnNo,
  256. MerIdcardNo = bind.SeoKeyword,
  257. SeoTitle = bind.SeoTitle,
  258. Field1 = bind.MerOperateType,
  259. Field2 = bind.Field1,
  260. Status = 1,
  261. });
  262. db.SaveChanges();
  263. // }
  264. }
  265. db.Dispose();
  266. }
  267. try
  268. {
  269. // PublicImportDataServiceRds.Instance.DoQueue(content, jobInfo.BrandInfo, BrandId);
  270. }
  271. catch{}
  272. }
  273. public void Test(JobMqMsg jobInfo, string date, int kind)
  274. {
  275. try
  276. {
  277. string orderString = jobInfo.OrderString;
  278. if (!string.IsNullOrEmpty(orderString))
  279. {
  280. string key = orderString.Split(':')[1];
  281. int BrandId = int.Parse(function.CheckInt(key.Split('_')[3]));
  282. string source = function.ReadInstance("/log/金控推送消息/" + date.Replace("-", "/") + "/content.log");
  283. string patten = "";
  284. if (kind == 1)
  285. {
  286. patten = "{.*?绑定.*?}]\"}";
  287. }
  288. else if (kind == 2)
  289. {
  290. patten = "{.*?2022年飞天系列-小宝电签.*?}";
  291. }
  292. else if (kind == 3)
  293. {
  294. patten = "{.*?otherFee.*?}";
  295. }
  296. if (!string.IsNullOrEmpty(patten))
  297. {
  298. MatchCollection mc = Regex.Matches(source, patten); //交易
  299. foreach (Match sub in mc)
  300. {
  301. string content = sub.Value;
  302. string Id = DoQueue(content, jobInfo.BrandInfo, BrandId);
  303. // 商户入库
  304. if (key.Contains("_bind_"))
  305. {
  306. int IdNum = int.Parse(Id);
  307. WebCMSEntities db = new WebCMSEntities();
  308. BindRecord bind = db.BindRecord.FirstOrDefault(m => m.Id == IdNum);
  309. if (bind != null)
  310. {
  311. string ProductType = BrandId.ToString();
  312. bool check = db.Merchants.Any(m => m.MerNo == bind.MerNo && m.ProductType == ProductType);
  313. if (!check)
  314. {
  315. db.Merchants.Add(new Merchants()
  316. {
  317. CreateDate = DateTime.Now,
  318. UpdateDate = DateTime.Now,
  319. MerNo = bind.MerNo, //商户编号
  320. MerName = bind.MerName, //商户名称
  321. AgentName = bind.AgentName, //机构名称
  322. ProductType = BrandId.ToString(), //产品类型
  323. Remark = "商户入库", //注释
  324. CreateTime = DateTime.Now, //创建时间
  325. UpdateTime = DateTime.Now, //更新时间
  326. SnNo = bind.MerSnNo, //SN号
  327. MerMobile = bind.MerNewSnNo,
  328. MerIdcardNo = bind.SeoKeyword,
  329. Status = 1,
  330. });
  331. db.SaveChanges();
  332. }
  333. }
  334. db.Dispose();
  335. }
  336. }
  337. }
  338. }
  339. }
  340. catch (Exception ex)
  341. {
  342. LogHelper.Instance.WriteLog(DateTime.Now.ToString() + ":" + ex.ToString(), "public_import_service");
  343. }
  344. }
  345. public string DoQueue(string data, Brand brand, int BrandId = 1)
  346. {
  347. if (string.IsNullOrEmpty(data))
  348. {
  349. return "0";
  350. }
  351. //数据开始入库
  352. data = data.Replace("null", "\"\"");
  353. JsonData jsonObj = JsonMapper.ToObject(data);
  354. string fields = "ProductType,";
  355. string fieldvals = BrandId + ",";
  356. fields += "SeoDescription,";
  357. fieldvals += "'" + HttpUtility.UrlEncode(data) + "',";
  358. if (!brand.IsCheck)
  359. {
  360. fields += "Status,";
  361. fieldvals += "1,";
  362. }
  363. string sourceCheckKey = "";
  364. foreach (FieldRelationTable field in brand.FieldRelation)
  365. {
  366. string fType = field.TargetFieldType;
  367. string fName = field.TargetFieldName;
  368. string sName = field.SourceFieldName;
  369. string val = "";
  370. if(sName == "#{now}#")
  371. {
  372. val = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  373. }
  374. else if (sName.Contains(","))
  375. {
  376. string[] flist = sName.Split(',');
  377. if (flist.Length == 2)
  378. {
  379. if (data.Contains("\"" + flist[1] + "\"") && jsonObj[flist[0]].ToJson().Contains("\"" + flist[1] + "\""))
  380. {
  381. val = jsonObj[flist[0]][flist[1]].ToString();
  382. }
  383. }
  384. else if (flist.Length == 3)
  385. {
  386. if (data.Contains("\"" + flist[2] + "\"") && jsonObj[flist[0]].ToJson().Contains("\"" + flist[1] + "\"") && jsonObj[flist[0]][flist[1]].ToJson().Contains("\"" + flist[2] + "\""))
  387. {
  388. val = jsonObj[flist[0]][flist[1]][flist[2]].ToString();
  389. }
  390. }
  391. }
  392. else
  393. {
  394. if (data.Contains("\"" + sName + "\""))
  395. {
  396. val = jsonObj[sName].ToString();
  397. }
  398. }
  399. string checkFields = "," + brand.CheckKey + ",";
  400. // if (fName == brand.CheckKey)
  401. if (checkFields.Contains("," + fName + ","))
  402. {
  403. if (fType == "number")
  404. {
  405. sourceCheckKey += " and " + fName + "=" + decimal.Parse(function.CheckNum(val)) + "";
  406. }
  407. else if (fType == "date")
  408. {
  409. sourceCheckKey += " and " + fName + "='" + DateTime.Parse(val).ToString("yyyy-MM-dd HH:mm:ss") + "'";
  410. }
  411. else if (fType == "timestempms")
  412. {
  413. sourceCheckKey += " and " + fName + "='" + function.ConvertIntDateTimeMini(long.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "'";
  414. }
  415. else if (fType == "timestemps")
  416. {
  417. sourceCheckKey += " and " + fName + "='" + function.ConvertIntDateTime(double.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "'";
  418. }
  419. else if (fType == "timestring")
  420. {
  421. string datetime = val.Substring(0, 4) + "-" + val.Substring(4, 2) + "-" + val.Substring(6, 2) + " " + val.Substring(8, 2) + ":" + val.Substring(10, 2) + ":" + val.Substring(12, 2);
  422. sourceCheckKey += " and " + fName + "='" + datetime + "'";
  423. }
  424. else
  425. {
  426. sourceCheckKey += " and " + fName + "='" + val + "'";
  427. }
  428. }
  429. fields += fName + ",";
  430. if (fType == "number")
  431. {
  432. fieldvals += decimal.Parse(function.CheckNum(val)) + ",";
  433. }
  434. else if (fType == "date")
  435. {
  436. fieldvals += "'" + DateTime.Parse(val).ToString("yyyy-MM-dd HH:mm:ss") + "',";
  437. }
  438. else if (fType == "timestempms")
  439. {
  440. fieldvals += "'" + function.ConvertIntDateTimeMini(long.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "',";
  441. }
  442. else if (fType == "timestemps")
  443. {
  444. fieldvals += "'" + function.ConvertIntDateTime(double.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "',";
  445. }
  446. else if (fType == "timestring")
  447. {
  448. string datetime = val.Substring(0, 4) + "-" + val.Substring(4, 2) + "-" + val.Substring(6, 2) + " " + val.Substring(8, 2) + ":" + val.Substring(10, 2) + ":" + val.Substring(12, 2);
  449. fieldvals += "'" + datetime + "',";
  450. }
  451. else
  452. {
  453. fieldvals += "'" + val + "',";
  454. }
  455. }
  456. string checksql = "select Id from " + brand.TargetTableName + " where ProductType='" + BrandId + "'" + sourceCheckKey;
  457. if(brand.TargetTableName == "BindRecord")
  458. {
  459. string Id = RedisDbconn.Instance.Get<string>("BindRecordIdLimit");
  460. if(string.IsNullOrEmpty(Id)) Id = "700000";
  461. checksql += " and Id>" + Id;
  462. }
  463. else if(brand.TargetTableName == "ActivateRecord")
  464. {
  465. string Id = RedisDbconn.Instance.Get<string>("ActivateRecordIdLimit");
  466. if(string.IsNullOrEmpty(Id)) Id = "500000";
  467. checksql += " and Id>" + Id;
  468. }
  469. else if(brand.TargetTableName == "TradeFluxRecord")
  470. {
  471. string Id = RedisDbconn.Instance.Get<string>("TradeFluxRecordIdLimit");
  472. if(string.IsNullOrEmpty(Id)) Id = "400000";
  473. checksql += " and Id>" + Id;
  474. }
  475. if(brand.TargetTableName == "TradeRecord")
  476. {
  477. // checksql = "select Id from " + brand.TargetTableName + " where Id>1520000 and ProductType='" + BrandId + "'" + sourceCheckKey;
  478. checksql = "select Id from TradeRecord where Id=0";
  479. }
  480. DataTable dt = dbconn.dtable(checksql);
  481. if (dt.Rows.Count < 1)
  482. {
  483. fields = fields.TrimEnd(',');
  484. fieldvals = fieldvals.TrimEnd(',');
  485. if(!fields.Contains("CreateDate"))
  486. {
  487. fields += ",CreateDate";
  488. fieldvals += ",'" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "'";
  489. }
  490. string sql = "insert into " + brand.TargetTableName + " (" + fields + ") values (" + fieldvals + ");select @@IDENTITY";
  491. dbconn.op(sql);
  492. PushData(brand.TargetTableName, fields, fieldvals);
  493. if(brand.TargetTableName == "BindRecord")
  494. {
  495. string[] fieldList = fields.Split(',');
  496. string[] fieldValList = fieldvals.Split(',');
  497. string mer_field = "CreateDate,UpdateDate,Remark,CreateTime,UpdateTime,Status";
  498. string mer_val = "'" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','商户入库','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "','" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "',1";
  499. int index = 0;
  500. foreach(string field in fieldList)
  501. {
  502. if(field == "MerNo")
  503. {
  504. mer_field += ",MerNo";
  505. mer_val += "," + fieldValList[index];
  506. }
  507. if(field == "MerName")
  508. {
  509. mer_field += ",MerName";
  510. mer_val += "," + fieldValList[index];
  511. }
  512. if(field == "AgentName")
  513. {
  514. mer_field += ",AgentName";
  515. mer_val += "," + fieldValList[index];
  516. }
  517. if(field == "ProductType")
  518. {
  519. mer_field += ",ProductType";
  520. mer_val += "," + fieldValList[index];
  521. }
  522. if(field == "MerSnNo")
  523. {
  524. mer_field += ",SnNo";
  525. mer_val += "," + fieldValList[index];
  526. }
  527. if(field == "MerNewSnNo")
  528. {
  529. mer_field += ",MerMobile";
  530. mer_val += "," + fieldValList[index];
  531. }
  532. if(field == "SeoKeyword")
  533. {
  534. mer_field += ",MerIdcardNo";
  535. mer_val += "," + fieldValList[index];
  536. }
  537. if(field == "SeoTitle")
  538. {
  539. mer_field += ",SeoTitle";
  540. mer_val += "," + fieldValList[index];
  541. }
  542. if(field == "MerOperateType")
  543. {
  544. mer_field += ",Field1";
  545. mer_val += "," + fieldValList[index];
  546. }
  547. if(field == "Field1")
  548. {
  549. mer_field += ",Field2";
  550. mer_val += "," + fieldValList[index];
  551. }
  552. index += 1;
  553. }
  554. sql = "insert into Merchants (" + mer_field + ") values (" + mer_val + ");";
  555. dbconn.op(sql);
  556. PushData("Merchants", mer_field, mer_val);
  557. }
  558. DataTable result = dbconn.dtable("select Id from " + brand.TargetTableName + " order by Id desc limit 1");
  559. if (result.Rows.Count > 0)
  560. {
  561. return result.Rows[0][0].ToString();
  562. }
  563. }
  564. return "0";
  565. }
  566. public void PushData(string tableName, string fields, string fieldvals)
  567. {
  568. try
  569. {
  570. Dictionary<string, string> spData = new Dictionary<string, string>();
  571. Dictionary<string, string> mainData = new Dictionary<string, string>();
  572. string[] fieldList = fields.Split(',');
  573. if(fieldList.Length > 0)
  574. {
  575. string[] fieldValList = fieldvals.Split(',');
  576. for (int i = 0; i < fieldList.Length; i++)
  577. {
  578. string fieldItem = fieldList[i];
  579. string fieldValItem = fieldValList[i].Trim('\'');
  580. mainData.Add(fieldItem, fieldValItem);
  581. if(fieldItem == "CreateDate" && !fields.Contains("CreateTime")) fieldItem = "createTime";
  582. if(fieldItem == "UpdateDate" && !fields.Contains("UpdateTime")) fieldItem = "updateTime";
  583. spData.Add(fieldItem.Substring(0, 1).ToLower() + fieldItem.Substring(1), fieldValItem);
  584. }
  585. }
  586. RabbitMQClient2.Instance.Push("SpDataQueue", tableName + "#cut#" + Newtonsoft.Json.JsonConvert.SerializeObject(spData));
  587. RabbitMQClient2.Instance.Push("MainDataQueue", tableName + "#cut#" + Newtonsoft.Json.JsonConvert.SerializeObject(mainData));
  588. }
  589. catch(Exception ex)
  590. {
  591. Utils.WriteLog(ex.ToString(), "通过MQ发送SP原始数据异常");
  592. }
  593. }
  594. #region 金控
  595. // 开发环境
  596. // string clientId = "1243966544896";
  597. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  598. // 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";
  599. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  600. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  601. // 生产环境
  602. string clientId = "4487378308096";
  603. string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
  604. string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
  605. 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=";
  606. string reqUrl = "https://push.mfe88.com/push-service/api/SETSERVICEFEE";
  607. string reqUrl2 = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  608. public bool Verify()
  609. {
  610. string data = "ZV0BBQ2hNgeZKKAPZ3XXEJGhp/h3+Mq5ejxuCI9SRbrDRls0XtfJRWboT5+J1sfHkb/J3eI4ThkTI/DjRNLK4x7fFYD62coClL7zDXeES42RXrpBik7VHHllUIS5nZFT23QME8kxRdo/6FH7Sv0J7IP5Qtqe70b3syv1jXmv8JozoP6DQjqHnlggpRM+4Ppks5PXorvHW7yI3uOgJL06t0GWDZIh7FRQ6UU41ayDsY0Z8j9o5quD8DSGJ1po6YPdmr2FpbFL5hs+buYhfEwsOwbvU5Aawbt+XuNXlU21wjeyC/8h2/yiPJSpCGjNXzzY4BBIhWDIbyxrbV+7SGIC+gNK2oQV0Ldtq9dXmljqA8e2dWsa8IaGaXmfo/85Ef2W5qIByrn42K+rA1nzhbR+L0WPGd4ugyzx6eiUl6T0oXVMaTIIoM6fndrm7RubsfNRZizrkQ+ocnAraMnGPZq84NpRp0Qs+pg8mlAIrqQ0avDutY1jGkzFXAljYGhiPvN7ntydmn2P2jgiPfh65VWumcXU+cp8d/nTD8eT/HmVbXUNMp/1ckP+VoK2wdowvgmgAruD3Fjfo8EghAfWEfuAVIsErxGxKCF17AUI8ZIqa+JYxxaA9vjxklavLmB9MAovx3JQSGXqXNNTy3LBljb1dZr3yk0ER9Qv8K4Bqc7Ti6gHHBFc7uu+wnqD7kTieMn++TpNo44MR8tGSmN6lzZKrio1czTyLLANLzzH4lBipTalGjgFnKcaNdVloW63DKkpz3qugCeBotRDdkH3T7DtYVz41lmJyLlxToeyFxXzqV0yqopR62QIghRO/vI9DpMDJclQMKEaCs9Py4qgMz2BmTqnESU42XDyNCMY5JVGpClZJgXNPmWLU0xrOu7B/tMEfThj9pNPBqNkbWQkLZ1MaSiMrfoHfQ7krt6TV6B2rhyfwrjKysXex4IHUX0nRTT55HcqQc38FlpeC4+kaTTSRs0HGMteiq+3BfDY0vHxH84x22WeN7oE7JbD/Ttd6Tn4";
  611. string signString = "cuo8Rp0Hhc1pzEkzvx3tlGV6aBhZoD3F+b1FM07IkCTQwTVzz0EzgO0auQt+Wqf9ndWERa7P9jTqHS4JKYQH+LGLXjVgQPekzrePNnIcVVFqjf3VC+xImxSxJLaChHxiF+ufDpU9symoesub51QRCPSUB3xuQ2uP2lSbVmgcjvw=";
  612. // var signer = SignerUtilities.GetSigner("SHA256withRSA");
  613. // var pubkey = Convert.FromBase64String(mfe88PublicKey);
  614. // // var pubkey = StrToToHexByte(mfe88PublicKey);
  615. // var publicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(pubkey);
  616. // signer.Init(false, publicKeyParam);
  617. // var signBytes = Convert.FromBase64String(signString);
  618. // var plainBytes = Convert.FromBase64String(data);
  619. // signer.BlockUpdate(plainBytes, 0, plainBytes.Length);
  620. // return signer.VerifySignature(signBytes);
  621. var toDecryptArray = Convert.FromBase64String(data);
  622. var toSignArray = Convert.FromBase64String(signString);
  623. // var pubkey = Encoding.UTF8.GetBytes(mfe88PublicKey);
  624. // using (var x509 = new X509Certificate2(pubkey))
  625. // {
  626. // using (var rsa = x509.GetRSAPublicKey())
  627. // {
  628. // return rsa.VerifyData(toDecryptArray, toSignArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  629. // }
  630. // }
  631. var rsa = RSA.Create();
  632. rsa.ImportRSAPublicKey(Convert.FromBase64String(mfe88PublicKey), out _);
  633. return rsa.VerifyData(toDecryptArray, toSignArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  634. }
  635. private byte[] StrToToHexByte(string hexString)
  636. {
  637. hexString = hexString.Replace(" ", "");
  638. if ((hexString.Length % 2) != 0)
  639. hexString += " ";
  640. byte[] returnBytes = new byte[hexString.Length / 2];
  641. for (int i = 0; i < returnBytes.Length; i++)
  642. returnBytes[i] = Convert.ToByte(hexString.Substring(i * 2, 2), 16);
  643. return returnBytes;
  644. }
  645. public string Decrypt(string data)
  646. {
  647. var toDecryptArray = Convert.FromBase64String(data);
  648. var rsa2 = RSA.Create();
  649. rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  650. string result = "";
  651. List<byte> cache = new List<byte>();
  652. for (int i = 0; i < toDecryptArray.Length; i++)
  653. {
  654. cache.Add(toDecryptArray[i]);
  655. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  656. {
  657. var ContentArray = rsa2.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  658. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  659. cache.Clear();
  660. }
  661. }
  662. return result;
  663. }
  664. public string SetDeposit(string sn, decimal serviceFee)
  665. {
  666. serviceFee = serviceFee * 100;
  667. Dictionary<string, string> headers = new Dictionary<string, string>();
  668. headers.Add("X-Client-ID", clientId);
  669. headers.Add("X-Security", "RSA");
  670. string content = "{\"sn\":\"" + sn + "\",\"serviceFee\":\"" + serviceFee.ToString("f0") + "\"}";
  671. content = Encrypt(content);
  672. string signstr = Sign(content);
  673. headers.Add("X-Sign", signstr);
  674. string req = "{\"param\":\"" + content + "\"}";
  675. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  676. return result;
  677. }
  678. public string SetFee(string merNo, string sn, decimal fee = 0.6M)
  679. {
  680. List<SetDepositList> rateDOs = new List<SetDepositList>();
  681. rateDOs.Add(new SetDepositList()
  682. {
  683. productSubType = "2020032007vz7Ux6",
  684. updateValue = fee,
  685. updateType = 0
  686. });
  687. Dictionary<string, string> headers = new Dictionary<string, string>();
  688. headers.Add("X-Client-ID", clientId);
  689. headers.Add("X-Security", "RSA");
  690. Dictionary<string, object> obj = new Dictionary<string, object>();
  691. obj.Add("merNo", merNo);
  692. obj.Add("sn", sn);
  693. obj.Add("batchUpdateType", 2);
  694. obj.Add("rateDOs", rateDOs);
  695. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  696. LogHelper.Instance.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  697. LogHelper.Instance.WriteLog(content, "设置金控机具费率");
  698. content = Encrypt2(content);
  699. string signstr = Sign(content);
  700. headers.Add("X-Sign", signstr);
  701. string req = "{\"param\":\"" + content + "\"}";
  702. string result = function.PostWebRequest(reqUrl2, req, headers, "application/json");
  703. LogHelper.Instance.WriteLog(result, "设置金控机具费率");
  704. return result;
  705. }
  706. public Dictionary<string, object> CallBack()
  707. {
  708. string trace = function.MD5_32(Guid.NewGuid().ToString()) + function.get_Random(8);
  709. Dictionary<string, object> obj = new Dictionary<string, object>();
  710. // Dictionary<string, string> headers = new Dictionary<string, string>();
  711. // headers.Add("X-Client-ID", clientId);
  712. // headers.Add("X-Security", "RSA");
  713. string content = "{\"code\":\"0000\",\"msg\":\"OK\"}";
  714. content = Encrypt(content);
  715. // string signstr = Sign(content);
  716. // headers.Add("X-Sign", signstr);
  717. obj.Add("code", "000000");
  718. obj.Add("message", "OK");
  719. obj.Add("trace", "");
  720. obj.Add("data", content);
  721. return obj;
  722. }
  723. public string Encrypt(string data)
  724. {
  725. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
  726. }
  727. public string Encrypt2(string data)
  728. {
  729. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt2(data);
  730. }
  731. public string Sign(string data)
  732. {
  733. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  734. var rsa = RSA.Create();
  735. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
  736. string result = "";
  737. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  738. result = Convert.ToBase64String(buffer);
  739. return result;
  740. // return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, clientPrivateKey, "").Sign(data);
  741. }
  742. #endregion
  743. #region 开店宝
  744. string KdbApiUrl = "https://kzy.kdb-tj.com:5055/api";
  745. string KDBAESKEY = "gvB%UOF3eBqKf!$k";
  746. // string Kdb_Rsa_PinlicKey = "MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAJzLZwTVqTU10mnPaxhTCQa89uR9hk/1MGJcKS6lpNDZaJFrXI48tTsk46jJgkXnDMqJoNIk+iLWXhKK/n8azQMCAwEAAQ==";
  747. string Kdb_Rsa_PrivateKey = "MIIBUwIBADANBgkqhkiG9w0BAQEFAASCAT0wggE5AgEAAkEAl2x9dSSCfNDik6VM2dn/SK1ONSbb7AKyXM1gHw8PMbzWN1pK7YGaPqHlIRbAeFeIvLKVeMxrji+63W6LpB0yDQIDAQABAkAfpHUnCIUYDhJ65f0EPTDCgCyqoL8uN3YMPIKMmvoC22/i7AC6zf/bWk4JdratN+gvvnjGgHQff6HH5dOQ6sbFAiEAxPYSLADzIv374J8O+LluXIcgI5zXm4r4dMtKbCmmWSsCIQDE0BRKsBcBZ9NvJ9Km+m/d1hN9v5hFT842zrkUFJmVpwIgBdYc17z3d3P7QL613NzxzkAazbNaGDvX/O4BOI9LZJ0CICrZElHgXGHV9NYyWU45H7mwLbYmzEPqx/5uqySQB4/pAiBgKYv3RGnsZ8Zm1EKAJjUX7ehdteBgPSA/UgIDZQ4oyw==";
  748. // 查询机构政策列表
  749. public string GetPolicyList()
  750. {
  751. string url = KdbApiUrl + "/marketing/plan/query/list";
  752. //[{"id":100014,"name":"韩测试营销方案(韩测试营销方案)"}]
  753. return PostKDB(url, "");
  754. }
  755. // 查询政策下的押金
  756. public string GetDepositList(string planId)
  757. {
  758. string url = KdbApiUrl + "/marketing/deposit/query/planId";
  759. string content = "{\"planId\":\"" + planId + "\"}";
  760. //[{"depositId":26,"depositName":"押0返0","amount":0.00},{"depositId":28,"depositName":"押199返199","amount":199.00},{"depositId":29,"depositName":"押299返299","amount":299.00},{"depositId":27,"depositName":"押99返99","amount":99.00}]
  761. return PostKDB(url, content);
  762. }
  763. // 修改押金接口
  764. public string ModifyDeposit(string PosSn, string depositId)
  765. {
  766. string url = KdbApiUrl + "/marketing/deposit/query/planId";
  767. string content = "{\"posSnStart\":\"" + PosSn + "\",\"posSnEnd\":\"" + PosSn + "\",\"depositId\":" + depositId + "}";
  768. return PostKDB(url, content);
  769. }
  770. public string KDBDecrypt(string data)
  771. {
  772. string result = AesDecrypt(data, KDBAESKEY);
  773. return result;
  774. }
  775. public string AesDecrypt(string str, string key)
  776. {
  777. if (string.IsNullOrEmpty(str)) return null;
  778. byte[] toEncryptArray = Convert.FromBase64String(str);
  779. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  780. {
  781. Key = Encoding.UTF8.GetBytes(key),
  782. Mode = System.Security.Cryptography.CipherMode.ECB,
  783. Padding = System.Security.Cryptography.PaddingMode.PKCS7,
  784. };
  785. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
  786. byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  787. return Encoding.UTF8.GetString(resultArray);
  788. }
  789. public string AesEncrypt(string str)
  790. {
  791. // if (string.IsNullOrEmpty(str)) return null;
  792. Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
  793. System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
  794. {
  795. Key = Encoding.UTF8.GetBytes(KDBAESKEY),
  796. Mode = System.Security.Cryptography.CipherMode.ECB,
  797. Padding = System.Security.Cryptography.PaddingMode.PKCS7
  798. };
  799. System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
  800. Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
  801. return Convert.ToBase64String(resultArray);
  802. }
  803. public string PostKDB(string path, string content)
  804. {
  805. string url = KdbApiUrl + path;
  806. content = PublicImportDataService.Instance.AesEncrypt(content);
  807. string timestamp = function.GetCurTimestamp().ToString();
  808. string sign = PublicImportDataService.Instance.KDBSign(content + timestamp);
  809. string req = "{\"agencyId\":\"3013890129\",\"content\":\"" + content + "\",\"timestamp\":\"" + timestamp + "\",\"sign\":\"" + sign + "\"}";
  810. string result = PostWebRequest(url, req, new Dictionary<string, string>());
  811. return result;
  812. }
  813. private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
  814. {
  815. string ret = string.Empty;
  816. try
  817. {
  818. byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
  819. // 设置提交的相关参数
  820. System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
  821. System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
  822. request.Method = "POST";
  823. request.KeepAlive = false;
  824. request.AllowAutoRedirect = true;
  825. request.ContentType = "application/json";
  826. foreach (string key in headers.Keys)
  827. {
  828. request.Headers.Add(key, headers[key]);
  829. }
  830. 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)";
  831. request.ContentLength = postData.Length;
  832. // 提交请求数据
  833. System.IO.Stream outputStream = request.GetRequestStream();
  834. outputStream.Write(postData, 0, postData.Length);
  835. outputStream.Close();
  836. System.Net.HttpWebResponse response;
  837. System.IO.Stream responseStream;
  838. System.IO.StreamReader reader;
  839. string srcString;
  840. response = request.GetResponse() as System.Net.HttpWebResponse;
  841. responseStream = response.GetResponseStream();
  842. reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
  843. srcString = reader.ReadToEnd();
  844. ret = srcString; //返回值赋值
  845. reader.Close();
  846. }
  847. // catch (System.Net.WebException ex)
  848. // {
  849. // System.Net.HttpWebResponse response = (System.Net.HttpWebResponse)ex.Response;
  850. // System.IO.Stream myResponseStream = response.GetResponseStream();
  851. // //获取响应内容
  852. // System.IO.StreamReader myStreamReader = new System.IO.StreamReader(myResponseStream);
  853. // ret = myStreamReader.ReadToEnd();
  854. // myResponseStream.Close();
  855. // }
  856. catch (Exception ex)
  857. {
  858. ret = "fail";
  859. LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
  860. }
  861. return ret;
  862. }
  863. public string KDBSign(string data)
  864. {
  865. var rsa = RSA.Create();
  866. var key = Convert.FromBase64String(Kdb_Rsa_PrivateKey);
  867. var content = Encoding.UTF8.GetBytes(data);
  868. rsa.ImportPkcs8PrivateKey(key, out _);
  869. var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  870. return Convert.ToBase64String(result);
  871. // return CSRSAHelper.Sign(data, Kdb_Rsa_PrivateKey, "utf-8");
  872. }
  873. #endregion
  874. #region 乐刷
  875. string LSPrivateKey = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAMjld3flY+R+9WTR2MvcR9qWISdmpayL3GNGg9gvzwkXkhDI/E7rX6ndLvVuaBbLWXB+UOh+8Pfw3Gvfv3D2GHZCTzPHOKrs2tyzqC8EmMUDQaoVOI2BY4vtB7IjNe9FlLGZx62JEJrMkHKnOSQxsi+flCoexKc2t1q7kQsO2F+3AgMBAAECgYBmQ7EB/mpQOXSPYucaN0L4eW3dEbqKUBPbEV0yInwgo7f+BWGyhsyGuooZ857W46Leyd5Dy8K8ZAbAfwCD7zJZsSzWsuvWQE991f+n0V7AAnKc3h4OsHa4oITUNo2nD3PvOpWfQx8vSuQuSFQgx0ExdnywS3So16mG2X6J2k87wQJBAPTfV10MNpA1e5oRdX4D4lQ2tVyg5GW72NMhUGWct/FvgcEW3V7xZ0z/gSLfFcGI8c4LGYWRVPIsBnWFx0LSZ6ECQQDSBoqXuF/LobfFFT3D47ixL8d+qDbOJ+ro3p4+iCkdxxJ/ncaqouxsr3fBbkSWh4t+UkbbihO/isPdBwLPZihXAkAc2jwHAKtlLogTzT7UzExcs92GvoZq3klcBy7b6i1aS1M0lycaSsNrNSfYHgUIOsSTDIfDTy59ImbYbhzeaMBBAkEAyfz6i4IJt3jXmZadKWk4NkhiT6CN3OUtGjsH69Hd4UKUuuFNsMwyHzD+NqzLEA5aDOoqNXftGDjnuAnHHRn9zwJAHqPHR5ZOKDN/ujeAIUTwmFFJh8vx6ujv7UTesBbtTsFYW6bZln+X6aS2G3Kdvz3e2cxQyH8ncc0yIh64a1fqyg==";
  876. public string LSDecrypt(string data, string sign)
  877. {
  878. var toDecryptArray = Convert.FromBase64String(sign);
  879. var rsa2 = RSA.Create();
  880. rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(LSPrivateKey), out _);
  881. var ContentArray = rsa2.Decrypt(toDecryptArray, RSAEncryptionPadding.Pkcs1);
  882. string aeskey = System.Text.Encoding.UTF8.GetString(ContentArray);
  883. return AesDecrypt(data, aeskey);
  884. }
  885. #endregion
  886. #region 海科
  887. string HKPrivateKey1 = "MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAK5iJ2q2nF+9jEnof9VYhMdbAgI0ZS4cYmgWTMW2JR61lJhR0GH+A/m6mjN9FsTS6Bq03u/+e6BKdE6VqMGk0q7asi2VZIgD59zj4HubS8EFrcb5ZprwmGLnG71cBga7V5EWnHxSB9BlbFt6rGeQiit8NSbv62NxGh1U+rAVE/a3AgMBAAECgYEApQGxpJNowls8bQ74LytUcMMX0ng7qXcoUq+PM6IX28gb9EmuMZtHrb05fjEGI3YiNGsjbNpTpqftCBMrHRjWVRgb0PDf/zD9YYrxmcP9DWKQjG5f1ygYtQBlnOPEX963Y2SXrsTKr4+szTpI8r6YqFfVbbooKVMesCBtshgg16kCQQDYHGDuCuOzULP84QvGi8z+wHNv0arFpYYxvwitntD7K3iolAh8gTDWeaC03MHruGM43ybCUi9EHhCrcVKjgpK1AkEAzpIUajdmAAwtwGg4G0v7tP/ulmpGhnALVN84gSMAc5f8D6aCnoUyle+GylwRBw9WblHBLxsOtARQIvvdphDrOwJBAIFvXc60zvQTHfoTf84G5VyfP4R1e2atYNZiqHv0Zw5IVxgAsaSAbBPI/SvWHH9mDGd/n+M6/fw6VZmZYfl0txECQQCQB3yifpPpDpTL5h7QsY8EKbqyN9GKpQ7Rk35zU/NZpawDQYcrfhXCQytJZx4cPQ53hxtae9QpoiQ58EEgLAXHAkABzJ/QDS1QfYrkP9t9X+Pny2iEuWGeIHyfsfSKQKr5pv16k1WqiIvlFRyDPl+aw5IOedkYb0vSkcU1KzjMW+Ra";
  888. string HKPrivateKey2 = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAIyARvyTYvGledv+4E3D8FxsS07pmzZYJkIdWxov/xApB6Mb2BVP6BkhsRyoySWbEyiYlZpx1A3b7D4yc7vD3WfB0i0cGPwMdJP/vGuzWfF2mLY0v4mJrxdXuGeWpfWnl4DP0aQS6qkUlei6f0vWS76wdpHvKUGb17Nz/f9ezr5tAgMBAAECgYBoLhn04Qil67BvKw+BOj+5GGfC7L81TamYrpHF2j8D6ZiLHnNcYjLUp8HfYVw9MT7EhFex/KNjX2ZOPDTKzpIVXofs9or1fqPYwUewBFHD9rwTrThKySdwbKrRAFNw7YXaJvMEdpPaxBBsMvfC5EdvrFejZ80TpGGfXyIXaxuC1QJBAP/6XsinJ4ZgoJj2PRPc5pWRqUssERV2w07LCPEGxxyECoyEzrTIoj7KcwSXYTSx2GGeEiSpijye9rFCHoHUNF8CQQCMg14KaLi3RjddGYatmO4SHr/IFlwpjL16rw+poOHN1WwMmex1qd3JfNab0vi5GEkFg1fAbIMRiwksvXS0ReCzAkB5/dcoJ0lV6D0BSPDIw5D8nQOieKjXotbneSmUvJctxtvEJhLg43E3HYJ9IKvJ0iv+MbgR0t63j0agKZOiagBfAkAuU3ViyynzStQf/rV3cI81LCwgpLaYAE3MMAFi9KbdvPqVoP3jwTBdKKp8z26vX8FbbvU0fNItq4BH3uKmOM+fAkAnBwxmorni7Y6Zs24pevDVqMpcF9SkOigRKsO9Lc1HuAJuxHEoPW5KeascBVe3HfYqgt4HWIxNy/d2MvpvNaWo";
  889. public string HKDecrypt(string data, string sign, int BrandId)
  890. {
  891. var toDecryptArray = Convert.FromBase64String(sign);
  892. var rsa2 = RSA.Create();
  893. string HKPrivateKey = "";
  894. if(BrandId == 8)
  895. {
  896. HKPrivateKey = HKPrivateKey1;
  897. }
  898. else if(BrandId == 9)
  899. {
  900. HKPrivateKey = HKPrivateKey2;
  901. }
  902. rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(HKPrivateKey), out _);
  903. var ContentArray = rsa2.Decrypt(toDecryptArray, RSAEncryptionPadding.Pkcs1);
  904. string aeskey = System.Text.Encoding.UTF8.GetString(ContentArray);
  905. return AesDecrypt(data, aeskey);
  906. }
  907. #endregion
  908. #region 联动
  909. //测试环境
  910. // string LDRequestUrl = "http://111.14.221.188:18066/CloudTerminalServiceAction/";
  911. // string AgentNo = "LD110014";
  912. // string LDPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC3WG04QXTzWBg2rj4BbSmnXVTqQiCk2lZ7yi2vur2LxsSc+KN0o1W9y2AkCHcFIAk2aAfMEMQYTO3HQ+F/Vcb27BNBSjnaOLfGv0PXNHKyVzC4EQLe4M5Pqd1wMl6NaZK+HnyrPBTnfsGeywhGJc1Ke96ANrydhk7UbwezydC7nQIDAQAB";
  913. // string LDPrivateKey = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAJwUiLkXb6zTpvNmB+zTZtuJi97/XCdGBWgiMn/2ayVEtRuarPOvMUQo0aX4Pb/JrfdFyQccXiXFGtmh/m5Mhfuj03t0pOTC4bniQAy2veytDhnRImL1xY9YjSMX+YRXI44VRcNUSefyNmBjL7V1HgbJOfnq/PmVkcBClTf1gtefAgMBAAECgYBRbYkS/34crWNJUq7JyFS+LllRounh9270r/qmtdmaXOkbmKuoinrqc11E+GjGuSJQghDp68vWaqmiZxhFVRkEqPzaesYyMJr73GB/efXhIRWWGCqQvARs3QgOFmCL2YsC/Vq7niI72mmNLC9jOUFN30vCnJH7xI2PljfQKBLwkQJBAN1/JRJmt+2ms/eeGsI/tgClciCAfHzTtAhPHRs7XL98mzk8IDGFjysKsiSacAym5e0xV1uB6ijsuAm61go4b8cCQQC0ZLVyKdUPadhzXSjyOqtk4HVzorHW6OkDCnMazL0CYLxdJOQzrpicPhww0TB397rqLC+FuGEOEcjrDnYyGQlpAkEAq4OU9VbM/h2kJg4rslcbXAzA/yH/Q7m7IuQAKeIhw7V9jShd1XsSjcXOhEGCmolyaeVXO+ixpdcH+6DNtURWaQJACh5L/ydRiBfLyEzFazDXREVC0UWi7AcMats/MZWiVGvQpPjYw/1bGghx1FsneNMwbMolsD5zUzK0LlsVTiIRYQJAZT0p0Mg3kqSaYO2JlC6fTkI9aHMJ50iDr8qLJ2JnrNFylDxxoHwKfA7GxA2KGotguGTKhw7xCp+IyrXtXiuNrQ==";
  914. //生产环境
  915. string LDRequestUrl = "http://ldys.umpay.com/service_exter/CloudTerminalServiceAction/";
  916. string AgentNo = "LD112692";
  917. string LDPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCGtWShTeFEgSSFx3PJXcjCOmS+OgtcUvPOHhpALY3Orm6t7rl1E0n3j7XlM049YwwtGRJI4OWhgrtR4/AnOMBXdyMBoKxF23uay1WQiNekzfUrTwil7/CRrQ+VlGgPe6dr3WQT2/HLbzMnJHeoIZ4KSIj/7pgAwTF4ciL1UC3awwIDAQAB";
  918. string LDPrivateKey = "MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAJwUiLkXb6zTpvNmB+zTZtuJi97/XCdGBWgiMn/2ayVEtRuarPOvMUQo0aX4Pb/JrfdFyQccXiXFGtmh/m5Mhfuj03t0pOTC4bniQAy2veytDhnRImL1xY9YjSMX+YRXI44VRcNUSefyNmBjL7V1HgbJOfnq/PmVkcBClTf1gtefAgMBAAECgYBRbYkS/34crWNJUq7JyFS+LllRounh9270r/qmtdmaXOkbmKuoinrqc11E+GjGuSJQghDp68vWaqmiZxhFVRkEqPzaesYyMJr73GB/efXhIRWWGCqQvARs3QgOFmCL2YsC/Vq7niI72mmNLC9jOUFN30vCnJH7xI2PljfQKBLwkQJBAN1/JRJmt+2ms/eeGsI/tgClciCAfHzTtAhPHRs7XL98mzk8IDGFjysKsiSacAym5e0xV1uB6ijsuAm61go4b8cCQQC0ZLVyKdUPadhzXSjyOqtk4HVzorHW6OkDCnMazL0CYLxdJOQzrpicPhww0TB397rqLC+FuGEOEcjrDnYyGQlpAkEAq4OU9VbM/h2kJg4rslcbXAzA/yH/Q7m7IuQAKeIhw7V9jShd1XsSjcXOhEGCmolyaeVXO+ixpdcH+6DNtURWaQJACh5L/ydRiBfLyEzFazDXREVC0UWi7AcMats/MZWiVGvQpPjYw/1bGghx1FsneNMwbMolsD5zUzK0LlsVTiIRYQJAZT0p0Mg3kqSaYO2JlC6fTkI9aHMJ50iDr8qLJ2JnrNFylDxxoHwKfA7GxA2KGotguGTKhw7xCp+IyrXtXiuNrQ==";
  919. public string LDEncrypt(string data)
  920. {
  921. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", LDPublicKey).Encrypt(data);
  922. }
  923. public string LDDecrypt(string data)
  924. {
  925. var toDecryptArray = Convert.FromBase64String(data);
  926. var toKey = Convert.FromBase64String(LDPrivateKey);
  927. var rsa = RSA.Create();
  928. rsa.ImportPkcs8PrivateKey(toKey, out _);
  929. string result = "";
  930. List<byte> cache = new List<byte>();
  931. for (int i = 0; i < toDecryptArray.Length; i++)
  932. {
  933. cache.Add(toDecryptArray[i]);
  934. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  935. {
  936. var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  937. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  938. cache.Clear();
  939. }
  940. }
  941. return result;
  942. }
  943. #endregion
  944. #region 联动掌中宝
  945. //测试环境
  946. // string LDZZBPrivateKey = "MIIEvwIBADANBgkqhkiG9w0BAQEFAASCBKkwggSlAgEAAoIBAQCtINYRcRSTpDwvG3rpSTwqqGXAz6/KGXNckoHQthooeie7If3vq2Ec/qdndAQu6p0V2LOwRrVhoznJ0Z+xCkf6CgpYflUQY8GJHedDoCgZEe3gKeMAdbNqcyJDb4FQWRJuy9W9vlnTQaKAGYDwNFsO3s4R0vmJvGl8Nix8s1Sd1SJy5IJioY+Vb2JTG9Ke2ZoDDl3rJl6FKdoIDnad28g/xAzioc84wNACLkeA/6pZfqsoqvjR7nr7FADypX3s9hxwGt6Zf4hxwb5RNYBLsy+EBOF13QsfoBetnYAghH6ppFm8GC9CRgnHOnOa1DnicXLn1Aah6L4zx94rAo8k6A9FAgMBAAECggEBAIk7pxRKS6JApEg/Ay3alGvH8mhk+JY9mFk/9NDpGFEPi2Dlr/GEKsWeAjqaFxrNdFk13jGTywErLoqQtIHUgXts7Ah7k5gbSvUSlBfh4wcEVEfFTCA4LFDsFLPZtmpnQJo8zx/JvFAeDd522OMOzUM7T6OHVbBdfkwscRUj3aYBUaK4XqhbWFP1otLEQqINUpYKa7BhxJ8JyLmxyEVa2kQqAomGnrD2So17F/lVeTtj8gL/cpShknUwhVb7aZiMbJPO77dR6s1aFlIKZYq8jMO88u60P7HhHnDQECRWmST4c/jecWkYTrKk3tsZ1DzGox15vuFOeQtcOSWhu0tAT+ECgYEA/s5KWNjUB7PI+7ul0JuLwtkbMkU2U+RLryE64YaE9syKJo66FLSQCKgJ07Au1O5BNdu4hySf54ePCT4+UUuvVahG2FedFlMdvFF6V5w/jtcDO1AhXFHgNwnNNoCdX8dqIWNvt2oHqCFbJsPevYysG0893Q/o3mk8hL1ko3+j8akCgYEArfCNFi7Mk4oUyrwR64e96vASUPQVC5DOR/qZhZynPRSb40PPUxJdoovzVWxUGwBtP0GnqkOHUgeMi0sKZMsnXEXDa3NjILCIL7q1DihjFkx10jlt2XWFaUQ7/L9LfWxAFGVIBcuhLp/llzO1a9LU/SOGVkz6OuEm+ubYFH476j0CgYEArvBtBPDhKeSacZKUtlOEsiMi0/HG6fQMrlFvPpV/xn4Jv40wXrTVSswr6wXEMXbemJ6g41AW5PwiDSOJ34DKAVJGSZRlioVIHhoGmA3zaRtf4aITNXIVMVRuayQEaFTeHcxKUC/gz+MO1N+XlqX1J87Q12xr4f94iF4LsWEZ6vkCgYA9n/Msf8olH4+8QCONMdt8iC/FFKT8IwKih8uqhdTOlCWiwByNDv2zoCfHBQlLQ7xw4972ONSRoHEPzLdS/JLmYyUYRZpCM6kcV+bbrD1m4hIAOC6OE8//ephSNKgXOKn/T97ThtCFR0s9ZamKGPky8koe+0jQYYLA89ZsdEjf9QKBgQCp6kM6yZCGknLbg8+iRCmum3iuav0Dm4Bnemvv9rawqwodmOgxReQtRQo596Yc+nkAPVOmNKYK9hetvLau29JJELKvWngZcASVs8QEMcaNRoKtqOx2Wb10Sp41G+FoCaNGY+aIWp7jvbP4AhbTuKii+e0j9OthrSAOyZFDVCzvUQ==";
  947. //生产环境
  948. string LDZZBPrivateKey = "MIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQDWEttbrR7VQ+07SRl1HlbWMfW2ao52Ycu4CVcJZdC5HwRDPJpTyJulf8CaaJ5hv2UCx218uj5Yo2WKiHGxPwU+Hj03VQX3Hn5K8TKIYyhD197QE+LHEdHcdIwB+GHyLR1U62HkEIcYyC0PdCLPkKkWsYhbJsCx5NbDzQPJnARg4g02Q/qP04VrnDSmY5piaKLXlGUXRhYcaKBw/PMYOt+4NCyMwM1VltgEQSKsN6Ta7PjhsQfj7TRStIBnpKbsolkp47acEEwEGK1w8ZyXND9vPVwkF4TzDQoSgk3+/4EydO3e8Afn8yseCy47GAdNZRQJeHF0FqyxMJbvHrKNfyabAgMBAAECggEAYVz8Nar8XgTh7dfmYzUkS5E3bvrxxnfePtrIojaTgs7PkoEKs9aGq/P5toCkoFJ7b5Migdr3JjtSoHpEM1g1WzZHo1XhO667w/wFfrCSjKCu7zZMKzw4larQTskYSxwnvgq8YA0AVM4eaGvqtTrXHMIsAUET3RT2dOFWuqhh+WmhM8nNthuKnfBoMi7mKd41OJcaoRUXoziEFyEMAd9AMWt285o7TvOFHDnBmhYYsBeTn3RSGEdG62khpteW4KW1aQi+nxHlMao9HdHxCsumPecmM+zF5DE3m1y8WlNaYi8aQrLkHbY8CwxGQ9tGxb+4CTGq4s3dy+RSNrWkcrRdIQKBgQD5pH+bvTJV8xph1PdWuNY5cM+fbqkmt+SGqeXaVRh3hOm7bPmpaTrcdQvm3gS0pYGHF93mgb1PsUBOBANT2Wd6uaIc1gBKjSwEG3Nd0cgQLyMQd4fNP/ET6jcfzg1qYBpLx0iKpyhCwmP1Or4Hy2no35hM2fbxv4WY2sVN7zweCwKBgQDbhnkYgj8zW3OkgNpBXwl3SEa/+K2gCj109zyVsUj8hP0FbDTGPvlx/VctXF5SOoTgs3x+G/96Px04PPzw/c4Tp9ToD2v6h1v64dAfEq35CwfNr/0LE/QEjAEUn1iLfjdQJoCroocYIkdaquHC1EOfr4if5U+A3rzY5jQ2MaTDsQKBgQDMaJNMVEiI8/ugK58y1Toj4mk+5H+AgoaOdUMN2SulgaFYpExxGQbnSLesHBLCT9qVYUeC3KzEOiCrQMHwwEzowmMpNVkbsiheXJPEOGeWSOJvM1BxEXA2nEryseduOK6PaefOEDz5HO5399dtznM0CRFNrBN1sxqTJF72B3O0LQKBgGHIXFhWa+Bsc+5qls1Xj9faEemg03XeGdHn7sye02vnsOyhbkB//IyR1CsYYcsu1dFhIarqvbmuM03BnMmbxBdtQqC7fdVyRb5Sp2mv4F52U1uDcKtmj+MWmcSd1csMxYamH9pT4ukVG8N/KmCmPBj9D1ZpxigZDvVuVQNuyX2BAoGBAI53c4yoq3M4zlIEmaWlEspfi13QmHqGJnzDM6glzj/WXybhfHDJprXXvzFdip6XTNEHeI1B5rpgQ1OfpBbPpwEzuUc7HIsgeLbMpHERXoYmuF0SG3lzQR0EnGrlWFDTpbXcCbANWx0i90e9Y47cuvGcpB4ZZSIKrjixpY8CMH2S";
  949. public string LDZZBDecrypt(string data)
  950. {
  951. var toDecryptArray = Convert.FromBase64String(data);
  952. var toKey = Convert.FromBase64String(LDZZBPrivateKey);
  953. var rsa = RSA.Create();
  954. rsa.ImportPkcs8PrivateKey(toKey, out _);
  955. var ContentArray = rsa.Decrypt(toDecryptArray, RSAEncryptionPadding.Pkcs1);
  956. string result = System.Text.Encoding.UTF8.GetString(ContentArray);
  957. // List<byte> cache = new List<byte>();
  958. // for (int i = 0; i < toDecryptArray.Length; i++)
  959. // {
  960. // cache.Add(toDecryptArray[i]);
  961. // if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  962. // {
  963. // var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  964. // result += System.Text.Encoding.UTF8.GetString(ContentArray);
  965. // cache.Clear();
  966. // }
  967. // }
  968. return result;
  969. }
  970. #endregion
  971. #region 盒易付
  972. //测试环境
  973. // string BoxPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjMQxp24mjxDTr13uPW0y+tiO1yXFGw7P/pPQ0oZKK7F6KstEaus7pLEywBZ5XRXE5jgkhR2TS7Ne7djJfbpn5yFc6pPlz3ZsOfBVeB88NEwhx6xzCGX2eqSSkO33n8w2G0xc2ss5HpYBarT00NBZWhrwOXpdRPYLOYHKVU3Rl+FA9xDw/wYfoWvrr+JSfHRGn/ENMmQFEdckAbPauKaQMrZD2kz+PRrhq56eWnCuVQPcaz/jroVT8qQEgkg2IsNy+DwfLOIqm8IySEpxnQ5wN/KvsQJc2wXDQNf9F5kvWwjoqSSP0qJS+oPRXET+zJb+WTk2y5M6AYoC9NodwsC4NwIDAQAB";
  974. //生产环境
  975. string BoxPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjmjoQirIYZBD9Qon2HkF4j/NAINXtJ7Lzq/WXxTF7t7mg7LNARt0+ZZaeWx8caq2fv5zdsGyyoInL23cBtDI5KmFfK69iA0ygQMK0WbiKqsUB1OpPbT3+9zLuadIJAznjA223lY6CIjTpdLZhaRjImNVqc60bdkx6YsQcA+xW+3r1JH4PPHb7yBEbkKIX8OhyX7U4p0TkbDkAobbjHr5YB9gmYLoSFJMOPfTtSExkv7/Y7IVR9poZAHcr3teFoAiXW3RzxelRtnXxIkl/6AUOKoL5fhr/UTUN+Q18uzNljYWr6SwnTI3EmtzgykaewWtZvV85Xdhe/BjiQ5Xor7YbwIDAQAB";
  976. public bool BoxVerifySign(string toSignStr, string signStr)
  977. {
  978. byte[] toSignByte = Encoding.Default.GetBytes(toSignStr);
  979. byte[] signByte = Convert.FromBase64String(signStr);
  980. var toKey = Convert.FromBase64String(BoxPublicKey);
  981. var rsaroot = RSA.Create();
  982. rsaroot.ImportSubjectPublicKeyInfo(toKey, out _);
  983. var publicKeyParameters = rsaroot.ExportParameters(false);
  984. using (var rsa = RSA.Create())
  985. {
  986. rsa.ImportParameters(publicKeyParameters);
  987. var sha256 = SHA256.Create();
  988. var hash = sha256.ComputeHash(toSignByte);
  989. return rsa.VerifyHash(hash, signByte, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  990. }
  991. }
  992. #endregion
  993. #region POSP
  994. //测试环境
  995. string PosPKey = "6v8cr0uyhtwtawda";
  996. //生产环境
  997. // string PosPKey = "6v8cr0uyhtwtawda";
  998. public string PosPDecrypt(string toSignStr, string signStr)
  999. {
  1000. string result = AesDecrypt(toSignStr, PosPKey);
  1001. SortedList<string, string> res = Newtonsoft.Json.JsonConvert.DeserializeObject<SortedList<string, string>>(result);
  1002. if(result.Contains("\"sign\""))
  1003. {
  1004. res.Remove("sign");
  1005. }
  1006. SortedList<string, string> newres = new SortedList<string, string>();
  1007. foreach(string key in res.Keys)
  1008. {
  1009. if(!string.IsNullOrEmpty(res[key]))
  1010. {
  1011. newres.Add(key, res[key]);
  1012. }
  1013. }
  1014. string signstr = function.BuildQueryString(newres) + PosPKey;
  1015. string sign = function.MD532(signstr).ToUpper();
  1016. if(signStr == sign)
  1017. {
  1018. return result;
  1019. }
  1020. return "";
  1021. }
  1022. #endregion
  1023. #region 来客吧L版
  1024. // 开发环境
  1025. // string clientId = "1243966544896";
  1026. // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
  1027. // 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";
  1028. // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
  1029. // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
  1030. // 生产环境
  1031. string lkbClientId = "4487378308096";
  1032. string lkbMfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC9w73juFDZe2n+D4Izav/B3VmkjP1b4wkc/4rv72DeK8uwGx1qWuEm+S5leG7v1YeyNXkTm/DW2I+iAJhvn+ILMErJCc8TK7hZlrzirhMTZtGB52Ai9IIi/SmpZtF9e2BV3S0feEvT83bi3ShnJDvsFsy6f0f/My63aNfjFcdaXwIDAQAB";
  1033. string lkbClientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC3YYYwaQyl+poYl+CQEFiLjQi7R0LEG73360Wup4frAy0zPZYlch3MwUChA7gPXVND/bUY+6vzJ3mkeoFvFtOkhrV0Wm8PWWnBVzanq3P91rFqMljMQlNxz4nBNeH2yHX9lCf6HQCYfjsYtadrGyUQw3ZMs+b0sMI2nZe/oKZo1wIDAQAB";
  1034. string lkbClientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBALdhhjBpDKX6mhiX4JAQWIuNCLtHQsQbvffrRa6nh+sDLTM9liVyHczBQKEDuA9dU0P9tRj7q/MneaR6gW8W06SGtXRabw9ZacFXNqerc/3WsWoyWMxCU3HPicE14fbIdf2UJ/odAJh+Oxi1p2sbJRDDdkyz5vSwwjadl7+gpmjXAgMBAAECgYA4+QKgvbJhSsdfRqhM+dcYnBuPW6dhmCDgCmdeyMvQdu8vET45qgeaGpxCqg4gL+VzpToDZgVZCPWg5TKbWeMsnjHJ4o3e/SYywRufHGDougTjYQcc4jZLjbefbGAbRIoSdZcYoJS9SOlFsSTyk5zkNmvFvxDH1mlw7ooYFmEi8QJBAO5vs6+wxuEwrYxm/y7tRuOUuIRuHv/HfRRPwTZUJMwR7YeQJ8HqWPZr8QukiE2YL+j7pEy/zscgW6tmAZzbNskCQQDE455wVPoWxFADaQvzrksWGF0qEce1ppnqf8DoHHQYQtUF3z8art/Kg8wJ/GbZxytR2REZzzaeqw3uGFyn21KfAkB44QZelqds+OmzGXBbkQ10SSx2bwGmOLNvvbM9YNE66AfcxzdwtucdHsIYXfSAKhx36EN2aXNiPkRbE57Tr8sJAkACPPgrHLwvEBI8x6/sGDogSSyd8s/LX9Z2FPeza8diEzhqtav4+K3wlmj2YBknNp1mc8o++d0MFrO01jAPdG3PAkBvAD3lZvd4m10Q92ikomH79IeQRh5mEBxfUsDXk+khHzjONmYgpo46TQBZ1okNW0amIemQhBbs/bEZZUGukPdn";
  1035. string lkbReqUrl = "https://push.mfe88.com/push-service/api/SETSERVICEFEE";
  1036. string lkbReqUrl2 = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
  1037. public bool LkbVerify()
  1038. {
  1039. string data = "ZV0BBQ2hNgeZKKAPZ3XXEJGhp/h3+Mq5ejxuCI9SRbrDRls0XtfJRWboT5+J1sfHkb/J3eI4ThkTI/DjRNLK4x7fFYD62coClL7zDXeES42RXrpBik7VHHllUIS5nZFT23QME8kxRdo/6FH7Sv0J7IP5Qtqe70b3syv1jXmv8JozoP6DQjqHnlggpRM+4Ppks5PXorvHW7yI3uOgJL06t0GWDZIh7FRQ6UU41ayDsY0Z8j9o5quD8DSGJ1po6YPdmr2FpbFL5hs+buYhfEwsOwbvU5Aawbt+XuNXlU21wjeyC/8h2/yiPJSpCGjNXzzY4BBIhWDIbyxrbV+7SGIC+gNK2oQV0Ldtq9dXmljqA8e2dWsa8IaGaXmfo/85Ef2W5qIByrn42K+rA1nzhbR+L0WPGd4ugyzx6eiUl6T0oXVMaTIIoM6fndrm7RubsfNRZizrkQ+ocnAraMnGPZq84NpRp0Qs+pg8mlAIrqQ0avDutY1jGkzFXAljYGhiPvN7ntydmn2P2jgiPfh65VWumcXU+cp8d/nTD8eT/HmVbXUNMp/1ckP+VoK2wdowvgmgAruD3Fjfo8EghAfWEfuAVIsErxGxKCF17AUI8ZIqa+JYxxaA9vjxklavLmB9MAovx3JQSGXqXNNTy3LBljb1dZr3yk0ER9Qv8K4Bqc7Ti6gHHBFc7uu+wnqD7kTieMn++TpNo44MR8tGSmN6lzZKrio1czTyLLANLzzH4lBipTalGjgFnKcaNdVloW63DKkpz3qugCeBotRDdkH3T7DtYVz41lmJyLlxToeyFxXzqV0yqopR62QIghRO/vI9DpMDJclQMKEaCs9Py4qgMz2BmTqnESU42XDyNCMY5JVGpClZJgXNPmWLU0xrOu7B/tMEfThj9pNPBqNkbWQkLZ1MaSiMrfoHfQ7krt6TV6B2rhyfwrjKysXex4IHUX0nRTT55HcqQc38FlpeC4+kaTTSRs0HGMteiq+3BfDY0vHxH84x22WeN7oE7JbD/Ttd6Tn4";
  1040. string signString = "cuo8Rp0Hhc1pzEkzvx3tlGV6aBhZoD3F+b1FM07IkCTQwTVzz0EzgO0auQt+Wqf9ndWERa7P9jTqHS4JKYQH+LGLXjVgQPekzrePNnIcVVFqjf3VC+xImxSxJLaChHxiF+ufDpU9symoesub51QRCPSUB3xuQ2uP2lSbVmgcjvw=";
  1041. var toDecryptArray = Convert.FromBase64String(data);
  1042. var toSignArray = Convert.FromBase64String(signString);
  1043. var rsa = RSA.Create();
  1044. rsa.ImportRSAPublicKey(Convert.FromBase64String(lkbMfe88PublicKey), out _);
  1045. return rsa.VerifyData(toDecryptArray, toSignArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  1046. }
  1047. private byte[] LkbStrToToHexByte(string hexString)
  1048. {
  1049. hexString = hexString.Replace(" ", "");
  1050. if ((hexString.Length % 2) != 0)
  1051. hexString += " ";
  1052. byte[] returnBytes = new byte[hexString.Length / 2];
  1053. for (int i = 0; i < returnBytes.Length; i++)
  1054. returnBytes[i] = Convert.ToByte(hexString.Substring(i * 2, 2), 16);
  1055. return returnBytes;
  1056. }
  1057. public string LkbDecrypt(string data)
  1058. {
  1059. var toDecryptArray = Convert.FromBase64String(data);
  1060. var rsa2 = RSA.Create();
  1061. rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(lkbClientPrivateKey), out _);
  1062. string result = "";
  1063. List<byte> cache = new List<byte>();
  1064. for (int i = 0; i < toDecryptArray.Length; i++)
  1065. {
  1066. cache.Add(toDecryptArray[i]);
  1067. if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
  1068. {
  1069. var ContentArray = rsa2.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
  1070. result += System.Text.Encoding.UTF8.GetString(ContentArray);
  1071. cache.Clear();
  1072. }
  1073. }
  1074. return result;
  1075. }
  1076. public string LkbSetDeposit(string sn, decimal serviceFee)
  1077. {
  1078. serviceFee = serviceFee * 100;
  1079. Dictionary<string, string> headers = new Dictionary<string, string>();
  1080. headers.Add("X-Client-ID", lkbClientId);
  1081. headers.Add("X-Security", "RSA");
  1082. string content = "{\"sn\":\"" + sn + "\",\"serviceFee\":\"" + serviceFee.ToString("f0") + "\"}";
  1083. content = LkbEncrypt(content);
  1084. string signstr = LkbSign(content);
  1085. headers.Add("X-Sign", signstr);
  1086. string req = "{\"param\":\"" + content + "\"}";
  1087. string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
  1088. return result;
  1089. }
  1090. public string LkbSetFee(string merNo, string sn, decimal fee = 0.6M)
  1091. {
  1092. List<SetDepositList> rateDOs = new List<SetDepositList>();
  1093. rateDOs.Add(new SetDepositList()
  1094. {
  1095. productSubType = "2020032007vz7Ux6",
  1096. updateValue = fee,
  1097. updateType = 0
  1098. });
  1099. Dictionary<string, string> headers = new Dictionary<string, string>();
  1100. headers.Add("X-Client-ID", lkbClientId);
  1101. headers.Add("X-Security", "RSA");
  1102. Dictionary<string, object> obj = new Dictionary<string, object>();
  1103. obj.Add("merNo", merNo);
  1104. obj.Add("sn", sn);
  1105. obj.Add("batchUpdateType", 2);
  1106. obj.Add("rateDOs", rateDOs);
  1107. string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
  1108. LogHelper.Instance.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
  1109. LogHelper.Instance.WriteLog(content, "设置金控机具费率");
  1110. content = LkbEncrypt2(content);
  1111. string signstr = LkbSign(content);
  1112. headers.Add("X-Sign", signstr);
  1113. string req = "{\"param\":\"" + content + "\"}";
  1114. string result = function.PostWebRequest(reqUrl2, req, headers, "application/json");
  1115. LogHelper.Instance.WriteLog(result, "设置金控机具费率");
  1116. return result;
  1117. }
  1118. public Dictionary<string, object> LkbCallBack(out string sign)
  1119. {
  1120. Dictionary<string, object> obj = new Dictionary<string, object>();
  1121. string content = "{\"code\":\"0000\",\"msg\":\"OK\"}";
  1122. content = LkbEncrypt(content);
  1123. sign = LkbSign(content);
  1124. obj.Add("code", "000000");
  1125. obj.Add("message", "OK");
  1126. obj.Add("data", content);
  1127. return obj;
  1128. }
  1129. public string LkbEncrypt(string data)
  1130. {
  1131. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", lkbMfe88PublicKey).Encrypt(data);
  1132. }
  1133. public string LkbEncrypt2(string data)
  1134. {
  1135. return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", lkbMfe88PublicKey).Encrypt2(data);
  1136. }
  1137. public string LkbSign(string data)
  1138. {
  1139. var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
  1140. var rsa = RSA.Create();
  1141. rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(lkbClientPrivateKey), out _);
  1142. string result = "";
  1143. var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
  1144. result = Convert.ToBase64String(buffer);
  1145. return result;
  1146. // return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, clientPrivateKey, "").Sign(data);
  1147. }
  1148. #endregion
  1149. #region 拉卡拉
  1150. string lklPubKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCskXFaaOCWaQpAhh2SjBLVQ4y1FHCNXAM/lF9yIfwG+2Qg6ggNwWBkmqa0DF8mWYAIxab0Z5fKSXautkt3rFoLMhwX6udSxo9A70As08oko+3i9DvnsqneQ769iVqgfPc9p47X9WFykgPt4tQQBdXH+fkkYEz4g7xWu7yrHGd1AwIDAQAB"; //解密推送消息
  1151. string lklPriKey = "MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAKyRcVpo4JZpCkCGHZKMEtVDjLUUcI1cAz+UX3Ih/Ab7ZCDqCA3BYGSaprQMXyZZgAjFpvRnl8pJdq62S3esWgsyHBfq51LGj0DvQCzTyiSj7eL0O+eyqd5Dvr2JWqB89z2njtf1YXKSA+3i1BAF1cf5+SRgTPiDvFa7vKscZ3UDAgMBAAECgYBB1Rxqsq7XAoxsMB3Q/cnjfOkNXZZQfyUoGKjOyCM24KmCmvVmlfp5drwY3M1humwLLKfz/h8chykVHqsspN4WXGFsW2DmRaySCfFX+xz/CD9hzpRXp2lhgEbsU853GWr6khqmCjOzhwRNUKp/cXmpYTU7AwdLlq1ED8KfKdDD9QJBAPGpwMMNOYPlSxfCx8Pw7BvuKwo7QWJH4XtfK4Y5OBf4FsN14J+cAwHQseSGU3BQPoGNfshQqEeyyINZDbY7jzUCQQC2zlA0hUOJv1FHgoklXJiEkx/B15ZbwiQquTCD/CxYymDUaJYNWxehXPOKMOGF3qGhrdEOpt1Sw9/EN18JaeJXAkEA4b6VFp+v7omu0A9f1KWlqaGeCvy3YzuKYljQq52fzKQvf38JyY9PL87nnnXsU6ph+VtX53+Q8wkLTcdOi8CvUQJAS3RvQK59CR9yAi1MRKKqxZYgtpcxFeDVotjbwK7W8zNdsm8U+KBP6af/UlwIyoPxfVXMg9q2YhI9i7U7Qhx1cwJBAOxZA4Zt9ye70/sv9w/KAYK/mXxUrJ6LFTDNOs7So1i6Fz5nyuOKHl8MWQi/5CXU7Baq10XZNkprFuRinG0exs0=";
  1152. public string LklDecrypt(string data)
  1153. {
  1154. return new RSAForJava().DecryptByPublicKey(data, lklPubKey);
  1155. }
  1156. #endregion
  1157. }
  1158. }