123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using GMUtilLib;
- using PTMedicalInsurance.Variables;
- using Newtonsoft.Json.Linq;
- using Newtonsoft.Json;
- using SM2Crypto.Lib;
- using PTMedicalInsurance.Common;
- namespace PTMedicalInsurance.Helper
- {
- class EncryptHelper
- {
- ////兰州眼视光测试-医保移动支付-测试环境-支付宝
- //private string ak = "1GJG37E3S0L93F60C80A000054283D1E";
- //private string sk = "AdMyUwp+FFXfxtJ7dslvbs+vtFSb2FDKQ8eHtUSyyac=";
- //private string appid = "1GJG37E3M0L83F60C80A00009D4B001C";
- //private string publicKey = "BGMQ0mQ8DMOUYx4JBvwzFNHUesHnIjUe3f8lTnz+VeOZI8VU8LO0k3IyYXYz1hH2M6jBbpMC1T9IJnACNRGfMoU = "; //平台公钥 验签
- //兰州眼视光测试-医保移动支付-测试环境-微信
- //private string ak = "1HF6DJEVD01B3F60C80A0000659F707C";
- //private string sk = "AMLwcdEq2KM8hmJtREdiik4cw00dgPqA2GXB0uew/LJs";
- //private string appid = "1HF6DJEV601A3F60C80A0000787DE1B9";
- //private string publicKey = "BKBXP3QCHUwBUZgJ72rf4TUKnGN1FnE9pY5fSxHRwbhUEE/44CxCsHr026+PEIWC/TmRX5Z7uGgA9AKNIYAceBk="; //平台公钥 验签
- //兰州普瑞眼视光医院-医保移动支付-正式环境-微信
- private string ak = "1HORGG3BI05S75430B0A000062B6208A";
- private string sk = "XxTei2H2xUo/F4v/QbkdcQBxe/2gjyZjTnepVkbdcJ8=";
- private string appid = "1HORGG3BA05R75430B0A00004664FD75";
- private string publicKey = "BJlWERvnklYQa3/yXK5AcBtDzssnY1uubA5acDkIhDd828nJakZa40MQ6vHtAVgsflSE02GhVCWrEhYLzBtLuiY="; //平台公钥 验签
- //兰州眼视光正式
- //private string ak = "1H62Q1KH205K76430B0A0000BF149773";
- //private string sk = "YbNObZNMdUgwgLUEyK4ixNSkaCF9OPtCdDth9APWYKU=";
- //private string appid = "1H62Q1KGP05J76430B0A00007144E257";
- //昆明普瑞测试
- //private string ak = "1H1INA1L90OH3F60C80A00008119D616";
- //private string sk = "APCIAgJqh3+AcK/IXL1WJD130i2q+6UblRxQzus3+sVw";
- //private string appid = "1H1INA1L30OG3F60C80A0000DEE43558";
- //昆明普瑞正式
- //private string ak = "1H62Q1KH205K76430B0A0000BF149773";
- //private string sk = "YbNObZNMdUgwgLUEyK4ixNSkaCF9OPtCdDth9APWYKU=";
- //private string appid = "1H62Q1KGP05J76430B0A00007144E257";
- //ak:1H62Q1KH205K76430B0A0000BF149773;sk:YbNObZNMdUgwgLUEyK4ixNSkaCF9OPtCdDth9APWYKU=;appid:1H62Q1KGP05J76430B0A00007144E257
- /// <summary>
- /// 移动支付加密
- /// </summary>
- /// <param name="data"></param>
- /// <param name="signText"></param>
- /// <returns></returns>
- public string encrypt(string data, ref string signText)
- {
- string encryptData = "";
- try
- {
- string strData = JsonConvert.SerializeObject(JObject.Parse(data), Newtonsoft.Json.Formatting.None);
- encryptData = SignUtils.encryptMsg(appid, ak, sk, strData, ref signText);
- return encryptData;
- }
- catch (Exception ex)
- {
- encryptData = ex.Message;
- return encryptData;
- }
- finally
- {
- //Global.writeLog("ak:" + appSecret + ";sk:" + privateKey + ";appid:" + appId, data, encryptData);
- }
- }
- public string encrypt(string data)
- {
- string encryptData = "";
- try
- {
- encryptData = GMUtilLib.SignUtil.encryptMsg(appid, ak, sk, data);
- return encryptData;
- }
- catch (Exception ex)
- {
- encryptData = ex.Message;
- return encryptData;
- }
- finally
- {
- Global.writeLog("ak:" + ak + ";sk:" + sk + ";appid:" + appid, data, encryptData);
- }
- }
- public string sign(string data)
- {
- string encryptData = "";
- try
- {
- encryptData = GMUtilLib.SignUtil.signSm3WithSm2(appid, ak, sk, data);
- return encryptData;
- }
- catch (Exception ex)
- {
- encryptData = ex.Message;
- return encryptData;
- }
- finally
- {
- Global.writeLog("ak:" + ak + ";sk:" + sk + ";appid:" + appid, data, encryptData);
- }
- }
- public int verify(string data,string encryptData)
- {
- string error ="";
- try
- {
- if (GMUtilLib.SignUtil.verifySm3WithSm2(data, ak, encryptData, sk)) return 0; else return -1;
- }
- catch (Exception ex)
- {
- error = ex.Message;
- return -1;
- }
- finally
- {
- Global.writeLog("ak:" + ak + ";sk:" + sk + ";appid:" + appid, data + ";" + encryptData, error);
- }
- }
- public bool verify(JObject signDto, string signData)
- {
- string error = "";
- try
- {
- bool b = SMUtil.verify(signDto, ak, publicKey, signData);
- if (b)
- {
- error = "成功";
- }
- else
- {
- error = "失败";
- }
- return b;
- }
- catch (Exception ex)
- {
- error = ex.Message;
- return false;
- }
- finally
- {
- Global.writeLog("验签:ak:" + ak + ";publicKey:" + publicKey + ";appid:" + appid, signDto.ToString() + ";" + signData, error);
- }
- }
- public string decrypt(string encryptData)
- {
- string data = "";
- try
- {
- data = GMUtilLib.SignUtil.decryptMsg(ak, sk, encryptData);
- return data;
- }
- catch (Exception ex)
- {
- data = ex.Message;
- return data;
- }
- finally
- {
- Global.writeLog("ak:" + ak + ";sk:" + sk + ";appid:" + appid, encryptData, data);
- }
- }
- public string decrypt00(string encryptData)
- {
- string data = "";
- try
- {
- data = SMUtil.decrypt(encryptData, appid, ak);
- return data;
- }
- catch (Exception ex)
- {
- data = ex.Message;
- return data;
- }
- finally
- {
- Global.writeLog("解密:ak:" + ak + ";sk:" + sk + ";appid:" + appid, encryptData, data);
- }
- }
- }
- }
|