123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847 |
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.Security.Cryptography;
- using System.Web;
- using System.Linq;
- using System.Text.RegularExpressions;
- using MySystem.Models;
- using Library;
- using LitJson;
- using System.Security.Cryptography.X509Certificates;
- using Org.BouncyCastle.Security;
- using Org.BouncyCastle.Crypto.Parameters;
- using System.Text;
- using Org.BouncyCastle.Crypto;
- using Org.BouncyCastle.Math;
- using System.Net.Http;
- using System.Threading.Tasks;
- namespace MySystem
- {
- public class PublicImportDataServiceRds
- {
- public readonly static PublicImportDataServiceRds Instance = new PublicImportDataServiceRds();
- private PublicImportDataServiceRds()
- { }
- public void Start(JobMqMsg jobInfo)
- {
- string data = "";
- try
- {
- string orderString = jobInfo.OrderString;
- if (!string.IsNullOrEmpty(orderString))
- {
- string key = orderString.Split(':')[1];
- int BrandId = int.Parse(function.CheckInt(key.Split('_')[3]));
- bool op = true;
- while (op)
- {
- data = RedisDbconn.Instance.RPop<string>(key);
- if (data != null)
- {
- string content = "";
- if (data.Contains("#cut#"))
- {
- string[] dataList = data.Replace("\r", "").Replace("\n", "").Split(new string[] { "#cut#" }, StringSplitOptions.None);
- JsonData jsonData = JsonMapper.ToObject(dataList[1]);
- if (BrandId == 1)
- {
- content = Decrypt(jsonData["param"].ToString());
- AppendLog(dataList[0], content, BrandId);
- InsertData(key, content, jobInfo, BrandId);
- }
- else if (BrandId == 2)
- {
- content = KDBDecrypt(jsonData["content"].ToString());
- AppendLog(dataList[0], content, BrandId);
- if (content.StartsWith("[") && content.EndsWith("]"))
- {
- content = content.Replace("null", "\"\"");
- content = content.Replace("NULL", "\"\"");
- JsonData list = JsonMapper.ToObject(content);
- for (int i = 0; i < list.Count; i++)
- {
- InsertData(key, list[i].ToJson(), jobInfo, BrandId);
- }
- }
- else
- {
- InsertData(key, content, jobInfo, BrandId);
- }
- }
- else if (BrandId == 4)
- {
- content = LSDecrypt(jsonData["data"].ToString(), jsonData["sign"].ToString());
- AppendLog(dataList[0], content, BrandId);
- InsertData(key, content, jobInfo, BrandId);
- }
- else if (BrandId == 8 || BrandId == 9)
- {
- content = HKDecrypt(jsonData["data"].ToString(), jsonData["sign"].ToString(), BrandId);
- AppendLog(dataList[0], content, BrandId);
- InsertData(key, content, jobInfo, BrandId);
- }
- else if (BrandId == 10)
- {
- content = LDDecrypt(jsonData["data"].ToString());
- AppendLog(dataList[0], content, BrandId);
- InsertData(key, content, jobInfo, BrandId);
- }
- else if (BrandId == 12)
- {
- content = dataList[1];
- JsonData header = JsonMapper.ToObject(dataList[0]);
- string signstr = header["X-Sign"][0].ToString();
- SortedList<string, string> dic = Newtonsoft.Json.JsonConvert.DeserializeObject<SortedList<string, string>>(content);
- string sign = function.BuildQueryString(dic);
- bool checkSign = BoxVerifySign(sign, signstr);
- if(checkSign)
- {
- AppendLog(dataList[0], content, BrandId);
- InsertData(key, content, jobInfo, BrandId);
- }
- }
- else
- {
- content = dataList[1];
- InsertData(key, content, jobInfo, BrandId);
- }
- if (dataList.Length > 2)
- {
- string fileName = dataList[2];
- if (System.IO.File.Exists(function.getPath("/redis/" + key + "/" + fileName + ".txt")))
- {
- System.IO.File.Delete(function.getPath("/redis/" + key + "/" + fileName + ".txt"));
- }
- }
- }
- }
- else
- {
- op = false;
- }
- }
- }
- // string Msg = "success";
- // jobInfo.Status = Msg == "success" ? 1 : 0;
- // jobInfo.Msg = Msg == "success" ? "执行完成" : Msg;
- // RabbitMQClient.Instance.SendMsg(Newtonsoft.Json.JsonConvert.SerializeObject(jobInfo), "PublicBack");
- }
- catch (Exception ex)
- {
- LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\n" + data + "\n" + ex.ToString(), "public_import_service");
- Start(jobInfo);
- }
- }
- private void AppendLog(string header, string content, int BrandId)
- {
- string BrandName = "";
- if (BrandId == 1)
- {
- BrandName = "金控";
- }
- else if (BrandId == 2)
- {
- BrandName = "开店宝";
- }
- else if (BrandId == 4)
- {
- BrandName = "乐刷";
- }
- else if (BrandId == 6)
- {
- BrandName = "立刷";
- }
- else if (BrandId == 8)
- {
- BrandName = "海科电签";
- }
- else if (BrandId == 9)
- {
- BrandName = "海科大POS";
- }
- else if (BrandId == 10)
- {
- BrandName = "联动电签";
- }
- else if (BrandId == 12)
- {
- BrandName = "盒易付";
- }
- LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\r\n" + header + "\r\n" + content, BrandName + "推送消息");
- }
- private void InsertData(string key, string content, JobMqMsg jobInfo, int BrandId)
- {
- string Id = DoQueue(content, jobInfo.BrandInfo, BrandId);
- // 商户入库
- if (key.Contains("_bind_") || key.Contains("_changebind_"))
- {
- int IdNum = int.Parse(Id);
- WebCMSEntities db = new WebCMSEntities();
- BindRecord bind = db.BindRecord.FirstOrDefault(m => m.Id == IdNum);
- if (bind != null)
- {
- // string ProductType = BrandId.ToString();
- // bool check = db.Merchants.Any(m => m.MerNo == bind.MerNo && m.ProductType == ProductType);
- // if (!check)
- // {
- db.Merchants.Add(new Merchants()
- {
- CreateDate = DateTime.Now,
- UpdateDate = DateTime.Now,
- MerNo = bind.MerNo, //商户编号
- MerName = bind.MerName, //商户名称
- AgentName = bind.AgentName, //机构名称
- ProductType = BrandId.ToString(), //产品类型
- Remark = "商户入库", //注释
- CreateTime = DateTime.Now, //创建时间
- UpdateTime = DateTime.Now, //更新时间
- SnNo = bind.MerSnNo, //SN号
- MerMobile = bind.MerNewSnNo,
- MerIdcardNo = bind.SeoKeyword,
- SeoTitle = bind.SeoTitle,
- Field1 = bind.MerOperateType,
- Field2 = bind.Field1,
- Status = 1,
- });
- db.SaveChanges();
- // }
- }
- db.Dispose();
- }
- }
- public void Test(JobMqMsg jobInfo, string date, int kind)
- {
- try
- {
- string orderString = jobInfo.OrderString;
- if (!string.IsNullOrEmpty(orderString))
- {
- string key = orderString.Split(':')[1];
- int BrandId = int.Parse(function.CheckInt(key.Split('_')[3]));
- string source = function.ReadInstance("/log/金控推送消息/" + date.Replace("-", "/") + "/content.log");
- string patten = "";
- if (kind == 1)
- {
- patten = "{.*?绑定.*?}]\"}";
- }
- else if (kind == 2)
- {
- patten = "{.*?2022年飞天系列-小宝电签.*?}";
- }
- else if (kind == 3)
- {
- patten = "{.*?otherFee.*?}";
- }
- if (!string.IsNullOrEmpty(patten))
- {
- MatchCollection mc = Regex.Matches(source, patten); //交易
- foreach (Match sub in mc)
- {
- string content = sub.Value;
- string Id = DoQueue(content, jobInfo.BrandInfo, BrandId);
- // 商户入库
- if (key.Contains("_bind_"))
- {
- int IdNum = int.Parse(Id);
- WebCMSEntities db = new WebCMSEntities();
- BindRecord bind = db.BindRecord.FirstOrDefault(m => m.Id == IdNum);
- if (bind != null)
- {
- string ProductType = BrandId.ToString();
- bool check = db.Merchants.Any(m => m.MerNo == bind.MerNo && m.ProductType == ProductType);
- if (!check)
- {
- db.Merchants.Add(new Merchants()
- {
- CreateDate = DateTime.Now,
- UpdateDate = DateTime.Now,
- MerNo = bind.MerNo, //商户编号
- MerName = bind.MerName, //商户名称
- AgentName = bind.AgentName, //机构名称
- ProductType = BrandId.ToString(), //产品类型
- Remark = "商户入库", //注释
- CreateTime = DateTime.Now, //创建时间
- UpdateTime = DateTime.Now, //更新时间
- SnNo = bind.MerSnNo, //SN号
- MerMobile = bind.MerNewSnNo,
- MerIdcardNo = bind.SeoKeyword,
- Status = 1,
- });
- db.SaveChanges();
- }
- }
- db.Dispose();
- }
- }
- }
- }
- }
- catch (Exception ex)
- {
- LogHelper.Instance.WriteLog(DateTime.Now.ToString() + ":" + ex.ToString(), "public_import_service");
- }
- }
- public string DoQueue(string data, Brand brand, int BrandId = 1)
- {
- if (string.IsNullOrEmpty(data))
- {
- return "0";
- }
- //数据开始入库
- data = data.Replace("null", "\"\"");
- JsonData jsonObj = JsonMapper.ToObject(data);
- string fields = "ProductType,";
- string fieldvals = BrandId + ",";
- fields += "SeoDescription,";
- fieldvals += "'" + HttpUtility.UrlEncode(data) + "',";
- if (!brand.IsCheck)
- {
- fields += "Status,";
- fieldvals += "1,";
- }
- string sourceCheckKey = "";
- foreach (FieldRelationTable field in brand.FieldRelation)
- {
- string fType = field.TargetFieldType;
- string fName = field.TargetFieldName;
- string sName = field.SourceFieldName;
- string val = "";
- if (sName.Contains(","))
- {
- string[] flist = sName.Split(',');
- if (flist.Length == 2)
- {
- if (data.Contains("\"" + flist[1] + "\""))
- {
- val = jsonObj[flist[0]][flist[1]].ToString();
- }
- }
- else if (flist.Length == 3)
- {
- if (data.Contains("\"" + flist[2] + "\""))
- {
- val = jsonObj[flist[0]][flist[1]][flist[2]].ToString();
- }
- }
- }
- else
- {
- if (data.Contains("\"" + sName + "\""))
- {
- val = jsonObj[sName].ToString();
- }
- }
- string checkFields = "," + brand.CheckKey + ",";
- // if (fName == brand.CheckKey)
- if (checkFields.Contains("," + fName + ","))
- {
- if (fType == "number")
- {
- sourceCheckKey += " and " + fName + "=" + decimal.Parse(function.CheckNum(val)) + "";
- }
- else if (fType == "date")
- {
- sourceCheckKey += " and " + fName + "='" + DateTime.Parse(val).ToString("yyyy-MM-dd HH:mm:ss") + "'";
- }
- else if (fType == "timestempms")
- {
- sourceCheckKey += " and " + fName + "='" + function.ConvertIntDateTimeMini(long.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "'";
- }
- else if (fType == "timestemps")
- {
- sourceCheckKey += " and " + fName + "='" + function.ConvertIntDateTime(double.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "'";
- }
- else if (fType == "timestring")
- {
- 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);
- sourceCheckKey += " and " + fName + "='" + datetime + "'";
- }
- else
- {
- sourceCheckKey += " and " + fName + "='" + val + "'";
- }
- }
- fields += fName + ",";
- if (fType == "number")
- {
- fieldvals += decimal.Parse(function.CheckNum(val)) + ",";
- }
- else if (fType == "date")
- {
- fieldvals += "'" + DateTime.Parse(val).ToString("yyyy-MM-dd HH:mm:ss") + "',";
- }
- else if (fType == "timestempms")
- {
- fieldvals += "'" + function.ConvertIntDateTimeMini(long.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "',";
- }
- else if (fType == "timestemps")
- {
- fieldvals += "'" + function.ConvertIntDateTime(double.Parse(val)).ToString("yyyy-MM-dd HH:mm:ss") + "',";
- }
- else if (fType == "timestring")
- {
- 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);
- fieldvals += "'" + datetime + "',";
- }
- else
- {
- fieldvals += "'" + val + "',";
- }
- }
- string checksql = "select Id from " + brand.TargetTableName + DateTime.Now.ToString("yyyyMM") + " where ProductType='" + BrandId + "'" + sourceCheckKey;
- if(brand.TargetTableName == "TradeRecord")
- {
- // checksql = "select Id from " + brand.TargetTableName + " where Id>1520000 and ProductType='" + BrandId + "'" + sourceCheckKey;
- checksql = "select Id from TradeRecord" + DateTime.Now.ToString("yyyyMM") + " where Id=0";
- }
- DataTable dt = CustomerSqlConn.dtable(checksql, AppConfig.Base.RdsSqlConn);
- if (dt.Rows.Count < 1)
- {
- fields = fields.TrimEnd(',');
- fieldvals = fieldvals.TrimEnd(',');
- if(!fields.Contains("CreateDate"))
- {
- fields += ",CreateDate";
- fieldvals += ",'" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "'";
- }
- string sql = "insert into " + brand.TargetTableName + DateTime.Now.ToString("yyyyMM") + " (" + fields + ") values (" + fieldvals + ");select @@IDENTITY";
- CustomerSqlConn.op(sql, AppConfig.Base.RdsSqlConn);
- DataTable result = CustomerSqlConn.dtable("select Id from " + brand.TargetTableName + DateTime.Now.ToString("yyyyMM") + " order by Id desc limit 1", AppConfig.Base.RdsSqlConn);
- if (result.Rows.Count > 0)
- {
- return result.Rows[0][0].ToString();
- }
- }
- return "0";
- }
- #region 金控
- // 开发环境
- // string clientId = "1243966544896";
- // string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCy8cg6/tXbSj2i1tyi7VztwJw7uNmqc3bS6sVIZkDYhTmcXhpV17jq4j2zz/tURwX8b3MdK1A1HTR1XRd7hl0w2UF9iFk6UezByJ5tdNDoffMCGJtVSThq+MCV+WQI26tJ/ub6bm7GPrzTR79fntN+nTniRM4trjONN2WzEhHEcwIDAQAB";
- // 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";
- // string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCb861uuey1252WdS8KPeBB+vm5AIBEKclsfBzVLY1cZXiiEbInCmsqT6fSO+A6wjWyJixGCzZICmUxhdBzuo3Du2YTbuo+fRlV6DW1mbguBV8/l2+LJvht0jl87J8N4skFUzvAeYKpWDX6dC6cLzjm5nyI1OrCQq0lsWPEMDCNAwIDAQAB";
- // string clientPrivateKey = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAJvzrW657LXbnZZ1Lwo94EH6+bkAgEQpyWx8HNUtjVxleKIRsicKaypPp9I74DrCNbImLEYLNkgKZTGF0HO6jcO7ZhNu6j59GVXoNbWZuC4FXz+Xb4sm+G3SOXzsnw3iyQVTO8B5gqlYNfp0LpwvOObmfIjU6sJCrSWxY8QwMI0DAgMBAAECgYAjE0dqo/6NWHu1H14ZG5mYvW31Ihu3OP7Im5GQkNI+ecQMD5bWGQ3JUmkYa8ce8BdLnjJO/q6SvWPNI5+ip87CYPH1SMXKUiSLzaCrw4xMySW9PSnudTzJwhrmlmyjYTAg70tHf2YQC4YkNvtkR+PJ2yf6JEKGFVgP5p2KyeKXgQJBANjGryxyu95QC3jIaggcYmGD36sVO/ns8Uyu8PkAHYOscuXRcV0L8LghIzPolcehj9bTbDLjiuNgeuyjNs2YBvMCQQC4K4uIXt0kVDLYzlJfhN1CsV90vQitcKdD8wTO0JRKfMCQ6UDSumU7lq+z4TxTlRYxmZjpgIqH+N0WohmEiwWxAkBEfuMzBD3gjSJS0+DNF0ruzSCLinYdDoVgWZbC1wp8ZK0ZeQh9AhzZ0X6yFDffkGlG1B9IJSXpmr68rwXOCM+JAkBkrKEUxc6bGk/FRluvDWEqIO2uUdtZfBhjQ4ggSdKWOUXGsUsXJn9KKKAZc4lXo0rDiFQXaIXRuE+bHLdYReqxAkAj0Kol0LkJgdl2PoBAeyQHTpt9nxaeNX56W7CN/srBA1O2wr+aoQiJaKsu9I0EeW3zaMJlLi3VyjU4wnF+yAsB";
- // 生产环境
- string clientId = "4487378308096";
- string mfe88PublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC2HxPVZ5ZIxIWfr24qB45PAz9WfjN9CiF1x9Lz3P/tVvIXFdBaUw+9zxCAPRDGQxJId7anjEjCOuAIKpFOiTPhVqHTHd3075FFsW5fL7lFCOFJELTj+mVamAIbKalAuRzIX0m0VQUXd+madB+yRQSBjkOIboAMYQ9amf99SqI9KwIDAQAB";
- string clientPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCrSrNKkBt/X8Fkd7viGpTMk+GdJgE+SvoA4PSjccpZoLWnwxXsC8K/7pfm9uGxPjte9e4RznXE5nuhSrcfls4lDWhTrGd/lj3Id8OCM+yEG+xilJs1lvXJjHDhL6/wa+TE5NSzWoKgXnyeHF3TSHMbUefLLtoKqL3j4h4lPqrjiQIDAQAB";
- 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=";
- string reqUrl = "https://push.mfe88.com/push-service/api/SETSERVICEFEE";
- string reqUrl2 = "https://push.mfe88.com/push-service/api/MODIFYPERPOSFEE";
-
- public bool Verify()
- {
- 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";
- string signString = "cuo8Rp0Hhc1pzEkzvx3tlGV6aBhZoD3F+b1FM07IkCTQwTVzz0EzgO0auQt+Wqf9ndWERa7P9jTqHS4JKYQH+LGLXjVgQPekzrePNnIcVVFqjf3VC+xImxSxJLaChHxiF+ufDpU9symoesub51QRCPSUB3xuQ2uP2lSbVmgcjvw=";
- // var signer = SignerUtilities.GetSigner("SHA256withRSA");
- // var pubkey = Convert.FromBase64String(mfe88PublicKey);
- // // var pubkey = StrToToHexByte(mfe88PublicKey);
- // var publicKeyParam = (RsaKeyParameters)PublicKeyFactory.CreateKey(pubkey);
- // signer.Init(false, publicKeyParam);
- // var signBytes = Convert.FromBase64String(signString);
- // var plainBytes = Convert.FromBase64String(data);
- // signer.BlockUpdate(plainBytes, 0, plainBytes.Length);
- // return signer.VerifySignature(signBytes);
- var toDecryptArray = Convert.FromBase64String(data);
- var toSignArray = Convert.FromBase64String(signString);
- // var pubkey = Encoding.UTF8.GetBytes(mfe88PublicKey);
- // using (var x509 = new X509Certificate2(pubkey))
- // {
- // using (var rsa = x509.GetRSAPublicKey())
- // {
- // return rsa.VerifyData(toDecryptArray, toSignArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
- // }
- // }
- var rsa = RSA.Create();
- rsa.ImportRSAPublicKey(Convert.FromBase64String(mfe88PublicKey), out _);
- return rsa.VerifyData(toDecryptArray, toSignArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
- }
- private byte[] StrToToHexByte(string hexString)
- {
- hexString = hexString.Replace(" ", "");
- if ((hexString.Length % 2) != 0)
- hexString += " ";
- byte[] returnBytes = new byte[hexString.Length / 2];
- for (int i = 0; i < returnBytes.Length; i++)
- returnBytes[i] = Convert.ToByte(hexString.Substring(i * 2, 2), 16);
- return returnBytes;
- }
- public string Decrypt(string data)
- {
- var toDecryptArray = Convert.FromBase64String(data);
- var rsa2 = RSA.Create();
- rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
- string result = "";
- List<byte> cache = new List<byte>();
- for (int i = 0; i < toDecryptArray.Length; i++)
- {
- cache.Add(toDecryptArray[i]);
- if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
- {
- var ContentArray = rsa2.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
- result += System.Text.Encoding.UTF8.GetString(ContentArray);
- cache.Clear();
- }
- }
- return result;
- }
- public string SetDeposit(string sn, decimal serviceFee)
- {
- serviceFee = serviceFee * 100;
- Dictionary<string, string> headers = new Dictionary<string, string>();
- headers.Add("X-Client-ID", clientId);
- headers.Add("X-Security", "RSA");
- string content = "{\"sn\":\"" + sn + "\",\"serviceFee\":\"" + serviceFee.ToString("f0") + "\"}";
- content = Encrypt(content);
- string signstr = Sign(content);
- headers.Add("X-Sign", signstr);
- string req = "{\"param\":\"" + content + "\"}";
- string result = function.PostWebRequest(reqUrl, req, headers, "application/json");
- return result;
- }
- public string SetFee(string merNo, string sn, decimal fee = 0.6M)
- {
- List<SetDepositList> rateDOs = new List<SetDepositList>();
- rateDOs.Add(new SetDepositList()
- {
- productSubType = "2020032007vz7Ux6",
- updateValue = fee,
- updateType = 0
- });
- Dictionary<string, string> headers = new Dictionary<string, string>();
- headers.Add("X-Client-ID", clientId);
- headers.Add("X-Security", "RSA");
- Dictionary<string, object> obj = new Dictionary<string, object>();
- obj.Add("merNo", merNo);
- obj.Add("sn", sn);
- obj.Add("batchUpdateType", 2);
- obj.Add("rateDOs", rateDOs);
- string content = Newtonsoft.Json.JsonConvert.SerializeObject(obj);
- LogHelper.Instance.WriteLog(DateTime.Now.ToString(), "设置金控机具费率");
- LogHelper.Instance.WriteLog(content, "设置金控机具费率");
- content = Encrypt2(content);
- string signstr = Sign(content);
- headers.Add("X-Sign", signstr);
- string req = "{\"param\":\"" + content + "\"}";
- string result = function.PostWebRequest(reqUrl2, req, headers, "application/json");
- LogHelper.Instance.WriteLog(result, "设置金控机具费率");
- return result;
- }
- public Dictionary<string, object> CallBack()
- {
- string trace = function.MD5_32(Guid.NewGuid().ToString()) + function.get_Random(8);
- Dictionary<string, object> obj = new Dictionary<string, object>();
- // Dictionary<string, string> headers = new Dictionary<string, string>();
- // headers.Add("X-Client-ID", clientId);
- // headers.Add("X-Security", "RSA");
- string content = "{\"code\":\"0000\",\"msg\":\"OK\"}";
- content = Encrypt(content);
- // string signstr = Sign(content);
- // headers.Add("X-Sign", signstr);
- obj.Add("code", "000000");
- obj.Add("message", "OK");
- obj.Add("trace", "");
- obj.Add("data", content);
- return obj;
- }
- public string Encrypt(string data)
- {
- return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt(data);
- }
- public string Encrypt2(string data)
- {
- return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", mfe88PublicKey).Encrypt2(data);
- }
- public string Sign(string data)
- {
- var toEncryptArray = System.Text.Encoding.UTF8.GetBytes(data);
- var rsa = RSA.Create();
- rsa.ImportPkcs8PrivateKey(Convert.FromBase64String(clientPrivateKey), out _);
- string result = "";
- var buffer = rsa.SignData(toEncryptArray, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
- result = Convert.ToBase64String(buffer);
- return result;
- // return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, clientPrivateKey, "").Sign(data);
- }
- #endregion
- #region 开店宝
- string KdbApiUrl = "https://kzy.kdb-tj.com:5055/api";
- string KDBAESKEY = "gvB%UOF3eBqKf!$k";
- // string Kdb_Rsa_PinlicKey = "MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAJzLZwTVqTU10mnPaxhTCQa89uR9hk/1MGJcKS6lpNDZaJFrXI48tTsk46jJgkXnDMqJoNIk+iLWXhKK/n8azQMCAwEAAQ==";
- string Kdb_Rsa_PrivateKey = "MIIBUwIBADANBgkqhkiG9w0BAQEFAASCAT0wggE5AgEAAkEAl2x9dSSCfNDik6VM2dn/SK1ONSbb7AKyXM1gHw8PMbzWN1pK7YGaPqHlIRbAeFeIvLKVeMxrji+63W6LpB0yDQIDAQABAkAfpHUnCIUYDhJ65f0EPTDCgCyqoL8uN3YMPIKMmvoC22/i7AC6zf/bWk4JdratN+gvvnjGgHQff6HH5dOQ6sbFAiEAxPYSLADzIv374J8O+LluXIcgI5zXm4r4dMtKbCmmWSsCIQDE0BRKsBcBZ9NvJ9Km+m/d1hN9v5hFT842zrkUFJmVpwIgBdYc17z3d3P7QL613NzxzkAazbNaGDvX/O4BOI9LZJ0CICrZElHgXGHV9NYyWU45H7mwLbYmzEPqx/5uqySQB4/pAiBgKYv3RGnsZ8Zm1EKAJjUX7ehdteBgPSA/UgIDZQ4oyw==";
- // 查询机构政策列表
- public string GetPolicyList()
- {
- string url = KdbApiUrl + "/marketing/plan/query/list";
- //[{"id":100014,"name":"韩测试营销方案(韩测试营销方案)"}]
- return PostKDB(url, "");
- }
- // 查询政策下的押金
- public string GetDepositList(string planId)
- {
- string url = KdbApiUrl + "/marketing/deposit/query/planId";
- string content = "{\"planId\":\"" + planId + "\"}";
- //[{"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}]
- return PostKDB(url, content);
- }
- // 修改押金接口
- public string ModifyDeposit(string PosSn, string depositId)
- {
- string url = KdbApiUrl + "/marketing/deposit/query/planId";
- string content = "{\"posSnStart\":\"" + PosSn + "\",\"posSnEnd\":\"" + PosSn + "\",\"depositId\":" + depositId + "}";
- return PostKDB(url, content);
- }
- public string KDBDecrypt(string data)
- {
- string result = AesDecrypt(data, KDBAESKEY);
- return result;
- }
- public string AesDecrypt(string str, string key)
- {
- if (string.IsNullOrEmpty(str)) return null;
- byte[] toEncryptArray = Convert.FromBase64String(str);
- System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
- {
- Key = Encoding.UTF8.GetBytes(key),
- Mode = System.Security.Cryptography.CipherMode.ECB,
- Padding = System.Security.Cryptography.PaddingMode.PKCS7,
- };
- System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateDecryptor();
- byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return Encoding.UTF8.GetString(resultArray);
- }
- public string AesEncrypt(string str)
- {
- // if (string.IsNullOrEmpty(str)) return null;
- Byte[] toEncryptArray = Encoding.UTF8.GetBytes(str);
- System.Security.Cryptography.RijndaelManaged rm = new System.Security.Cryptography.RijndaelManaged
- {
- Key = Encoding.UTF8.GetBytes(KDBAESKEY),
- Mode = System.Security.Cryptography.CipherMode.ECB,
- Padding = System.Security.Cryptography.PaddingMode.PKCS7
- };
- System.Security.Cryptography.ICryptoTransform cTransform = rm.CreateEncryptor();
- Byte[] resultArray = cTransform.TransformFinalBlock(toEncryptArray, 0, toEncryptArray.Length);
- return Convert.ToBase64String(resultArray);
- }
- public string PostKDB(string path, string content)
- {
- string url = KdbApiUrl + path;
- content = PublicImportDataService.Instance.AesEncrypt(content);
- string timestamp = function.GetCurTimestamp().ToString();
- string sign = PublicImportDataService.Instance.KDBSign(content + timestamp);
- string req = "{\"agencyId\":\"3013890129\",\"content\":\"" + content + "\",\"timestamp\":\"" + timestamp + "\",\"sign\":\"" + sign + "\"}";
- string result = PostWebRequest(url, req, new Dictionary<string, string>());
- return result;
- }
- private string PostWebRequest(string postUrl, string paramData, Dictionary<string, string> headers)
- {
- string ret = string.Empty;
- try
- {
- byte[] postData = System.Text.Encoding.UTF8.GetBytes(paramData);
- // 设置提交的相关参数
- System.Net.HttpWebRequest request = System.Net.WebRequest.Create(postUrl) as System.Net.HttpWebRequest;
- System.Text.Encoding myEncoding = System.Text.Encoding.UTF8;
- request.Method = "POST";
- request.KeepAlive = false;
- request.AllowAutoRedirect = true;
- request.ContentType = "application/json";
- foreach (string key in headers.Keys)
- {
- request.Headers.Add(key, headers[key]);
- }
- 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)";
- request.ContentLength = postData.Length;
- // 提交请求数据
- System.IO.Stream outputStream = request.GetRequestStream();
- outputStream.Write(postData, 0, postData.Length);
- outputStream.Close();
- System.Net.HttpWebResponse response;
- System.IO.Stream responseStream;
- System.IO.StreamReader reader;
- string srcString;
- response = request.GetResponse() as System.Net.HttpWebResponse;
- responseStream = response.GetResponseStream();
- reader = new System.IO.StreamReader(responseStream, System.Text.Encoding.UTF8);
- srcString = reader.ReadToEnd();
- ret = srcString; //返回值赋值
- reader.Close();
- }
- // catch (System.Net.WebException ex)
- // {
- // System.Net.HttpWebResponse response = (System.Net.HttpWebResponse)ex.Response;
- // System.IO.Stream myResponseStream = response.GetResponseStream();
- // //获取响应内容
- // System.IO.StreamReader myStreamReader = new System.IO.StreamReader(myResponseStream);
- // ret = myStreamReader.ReadToEnd();
- // myResponseStream.Close();
- // }
- catch (Exception ex)
- {
- ret = "fail";
- LogHelper.Instance.WriteLog(DateTime.Now.ToString() + "\r\n" + ex.ToString(), "请求开店宝API异常");
- }
- return ret;
- }
- public string KDBSign(string data)
- {
- var rsa = RSA.Create();
- var key = Convert.FromBase64String(Kdb_Rsa_PrivateKey);
- var content = Encoding.UTF8.GetBytes(data);
- rsa.ImportPkcs8PrivateKey(key, out _);
- var result = rsa.SignData(content, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
- return Convert.ToBase64String(result);
- // return CSRSAHelper.Sign(data, Kdb_Rsa_PrivateKey, "utf-8");
- }
- #endregion
- #region 乐刷
- 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==";
- public string LSDecrypt(string data, string sign)
- {
- var toDecryptArray = Convert.FromBase64String(sign);
- var rsa2 = RSA.Create();
- rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(LSPrivateKey), out _);
- var ContentArray = rsa2.Decrypt(toDecryptArray, RSAEncryptionPadding.Pkcs1);
- string aeskey = System.Text.Encoding.UTF8.GetString(ContentArray);
- return AesDecrypt(data, aeskey);
- }
- #endregion
- #region 海科
- string HKPrivateKey1 = "MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAK5iJ2q2nF+9jEnof9VYhMdbAgI0ZS4cYmgWTMW2JR61lJhR0GH+A/m6mjN9FsTS6Bq03u/+e6BKdE6VqMGk0q7asi2VZIgD59zj4HubS8EFrcb5ZprwmGLnG71cBga7V5EWnHxSB9BlbFt6rGeQiit8NSbv62NxGh1U+rAVE/a3AgMBAAECgYEApQGxpJNowls8bQ74LytUcMMX0ng7qXcoUq+PM6IX28gb9EmuMZtHrb05fjEGI3YiNGsjbNpTpqftCBMrHRjWVRgb0PDf/zD9YYrxmcP9DWKQjG5f1ygYtQBlnOPEX963Y2SXrsTKr4+szTpI8r6YqFfVbbooKVMesCBtshgg16kCQQDYHGDuCuOzULP84QvGi8z+wHNv0arFpYYxvwitntD7K3iolAh8gTDWeaC03MHruGM43ybCUi9EHhCrcVKjgpK1AkEAzpIUajdmAAwtwGg4G0v7tP/ulmpGhnALVN84gSMAc5f8D6aCnoUyle+GylwRBw9WblHBLxsOtARQIvvdphDrOwJBAIFvXc60zvQTHfoTf84G5VyfP4R1e2atYNZiqHv0Zw5IVxgAsaSAbBPI/SvWHH9mDGd/n+M6/fw6VZmZYfl0txECQQCQB3yifpPpDpTL5h7QsY8EKbqyN9GKpQ7Rk35zU/NZpawDQYcrfhXCQytJZx4cPQ53hxtae9QpoiQ58EEgLAXHAkABzJ/QDS1QfYrkP9t9X+Pny2iEuWGeIHyfsfSKQKr5pv16k1WqiIvlFRyDPl+aw5IOedkYb0vSkcU1KzjMW+Ra";
- string HKPrivateKey2 = "MIICdQIBADANBgkqhkiG9w0BAQEFAASCAl8wggJbAgEAAoGBAIyARvyTYvGledv+4E3D8FxsS07pmzZYJkIdWxov/xApB6Mb2BVP6BkhsRyoySWbEyiYlZpx1A3b7D4yc7vD3WfB0i0cGPwMdJP/vGuzWfF2mLY0v4mJrxdXuGeWpfWnl4DP0aQS6qkUlei6f0vWS76wdpHvKUGb17Nz/f9ezr5tAgMBAAECgYBoLhn04Qil67BvKw+BOj+5GGfC7L81TamYrpHF2j8D6ZiLHnNcYjLUp8HfYVw9MT7EhFex/KNjX2ZOPDTKzpIVXofs9or1fqPYwUewBFHD9rwTrThKySdwbKrRAFNw7YXaJvMEdpPaxBBsMvfC5EdvrFejZ80TpGGfXyIXaxuC1QJBAP/6XsinJ4ZgoJj2PRPc5pWRqUssERV2w07LCPEGxxyECoyEzrTIoj7KcwSXYTSx2GGeEiSpijye9rFCHoHUNF8CQQCMg14KaLi3RjddGYatmO4SHr/IFlwpjL16rw+poOHN1WwMmex1qd3JfNab0vi5GEkFg1fAbIMRiwksvXS0ReCzAkB5/dcoJ0lV6D0BSPDIw5D8nQOieKjXotbneSmUvJctxtvEJhLg43E3HYJ9IKvJ0iv+MbgR0t63j0agKZOiagBfAkAuU3ViyynzStQf/rV3cI81LCwgpLaYAE3MMAFi9KbdvPqVoP3jwTBdKKp8z26vX8FbbvU0fNItq4BH3uKmOM+fAkAnBwxmorni7Y6Zs24pevDVqMpcF9SkOigRKsO9Lc1HuAJuxHEoPW5KeascBVe3HfYqgt4HWIxNy/d2MvpvNaWo";
- public string HKDecrypt(string data, string sign, int BrandId)
- {
- var toDecryptArray = Convert.FromBase64String(sign);
- var rsa2 = RSA.Create();
- string HKPrivateKey = "";
- if(BrandId == 8)
- {
- HKPrivateKey = HKPrivateKey1;
- }
- else if(BrandId == 9)
- {
- HKPrivateKey = HKPrivateKey2;
- }
- rsa2.ImportPkcs8PrivateKey(Convert.FromBase64String(HKPrivateKey), out _);
- var ContentArray = rsa2.Decrypt(toDecryptArray, RSAEncryptionPadding.Pkcs1);
- string aeskey = System.Text.Encoding.UTF8.GetString(ContentArray);
- return AesDecrypt(data, aeskey);
- }
- #endregion
- #region 联动
- //测试环境
- // string LDRequestUrl = "http://111.14.221.188:18066/CloudTerminalServiceAction/";
- // string AgentNo = "LD110014";
- // string LDPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC3WG04QXTzWBg2rj4BbSmnXVTqQiCk2lZ7yi2vur2LxsSc+KN0o1W9y2AkCHcFIAk2aAfMEMQYTO3HQ+F/Vcb27BNBSjnaOLfGv0PXNHKyVzC4EQLe4M5Pqd1wMl6NaZK+HnyrPBTnfsGeywhGJc1Ke96ANrydhk7UbwezydC7nQIDAQAB";
- // 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==";
- //生产环境
- string LDRequestUrl = "http://ldys.umpay.com/service_exter/CloudTerminalServiceAction/";
- string AgentNo = "LD112692";
- string LDPublicKey = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCGtWShTeFEgSSFx3PJXcjCOmS+OgtcUvPOHhpALY3Orm6t7rl1E0n3j7XlM049YwwtGRJI4OWhgrtR4/AnOMBXdyMBoKxF23uay1WQiNekzfUrTwil7/CRrQ+VlGgPe6dr3WQT2/HLbzMnJHeoIZ4KSIj/7pgAwTF4ciL1UC3awwIDAQAB";
- 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==";
- public string LDEncrypt(string data)
- {
- return new RSAHelper(RSAType.RSA, System.Text.Encoding.UTF8, "", LDPublicKey).Encrypt(data);
- }
- public string LDDecrypt(string data)
- {
- var toDecryptArray = Convert.FromBase64String(data);
- var toKey = Convert.FromBase64String(LDPrivateKey);
- var rsa = RSA.Create();
- rsa.ImportPkcs8PrivateKey(toKey, out _);
- string result = "";
- List<byte> cache = new List<byte>();
- for (int i = 0; i < toDecryptArray.Length; i++)
- {
- cache.Add(toDecryptArray[i]);
- if ((i + 1) % 128 == 0 || i + 1 == toDecryptArray.Length)
- {
- var ContentArray = rsa.Decrypt(cache.ToArray(), RSAEncryptionPadding.Pkcs1);
- result += System.Text.Encoding.UTF8.GetString(ContentArray);
- cache.Clear();
- }
- }
- return result;
- }
- #endregion
-
- #region 盒易付
- //测试环境
- // string BoxPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjMQxp24mjxDTr13uPW0y+tiO1yXFGw7P/pPQ0oZKK7F6KstEaus7pLEywBZ5XRXE5jgkhR2TS7Ne7djJfbpn5yFc6pPlz3ZsOfBVeB88NEwhx6xzCGX2eqSSkO33n8w2G0xc2ss5HpYBarT00NBZWhrwOXpdRPYLOYHKVU3Rl+FA9xDw/wYfoWvrr+JSfHRGn/ENMmQFEdckAbPauKaQMrZD2kz+PRrhq56eWnCuVQPcaz/jroVT8qQEgkg2IsNy+DwfLOIqm8IySEpxnQ5wN/KvsQJc2wXDQNf9F5kvWwjoqSSP0qJS+oPRXET+zJb+WTk2y5M6AYoC9NodwsC4NwIDAQAB";
- //生产环境
- string BoxPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAjmjoQirIYZBD9Qon2HkF4j/NAINXtJ7Lzq/WXxTF7t7mg7LNARt0+ZZaeWx8caq2fv5zdsGyyoInL23cBtDI5KmFfK69iA0ygQMK0WbiKqsUB1OpPbT3+9zLuadIJAznjA223lY6CIjTpdLZhaRjImNVqc60bdkx6YsQcA+xW+3r1JH4PPHb7yBEbkKIX8OhyX7U4p0TkbDkAobbjHr5YB9gmYLoSFJMOPfTtSExkv7/Y7IVR9poZAHcr3teFoAiXW3RzxelRtnXxIkl/6AUOKoL5fhr/UTUN+Q18uzNljYWr6SwnTI3EmtzgykaewWtZvV85Xdhe/BjiQ5Xor7YbwIDAQAB";
-
- public bool BoxVerifySign(string toSignStr, string signStr)
- {
- byte[] toSignByte = Encoding.Default.GetBytes(toSignStr);
- byte[] signByte = Convert.FromBase64String(signStr);
- var toKey = Convert.FromBase64String(BoxPublicKey);
- var rsaroot = RSA.Create();
- rsaroot.ImportSubjectPublicKeyInfo(toKey, out _);
- var publicKeyParameters = rsaroot.ExportParameters(false);
- using (var rsa = RSA.Create())
- {
- rsa.ImportParameters(publicKeyParameters);
- var sha256 = SHA256.Create();
- var hash = sha256.ComputeHash(toSignByte);
- return rsa.VerifyHash(hash, signByte, HashAlgorithmName.SHA256, RSASignaturePadding.Pkcs1);
- }
- }
- #endregion
- }
- }
|