using System; using System.Collections.Generic; using System.Linq; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Microsoft.AspNetCore.Authorization; using System.Web; using MySystem.Areas.Admin.Controllers; using LitJson; using Library; using System.IO; using Aop.Api.Util; namespace MySystem.Areas.Api.Controllers.v1 { [Area("Api")] [Route("Api/[controller]/[action]")] public class AlipayController : BaseController { public AlipayController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { } #region 支付宝支付回调 public string Notice() { StreamReader sr = new StreamReader(Request.Body); string requestMes = sr.ReadToEnd(); // function.WriteLog(DateTime.Now.ToString() + "\r\n" + requestMes + "\r\n\r\n", "支付宝支付回调"); return PayCallBack("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxycehrmnTl2IaIAECP+0HWc1eWGM/T6x022K7K6fdf+xoyC97TBJaG4G3Bcon4gsJX+Sad5IA9OJIQ4eN1joM35hIlwcFZ6MmCuVXx/SMAKThIjK0jsRc6aTxVQG+GVCgS7dXMKb4Sm+vK2wEM6xtDeqcfYMB0BqGZRvxbIV59a2ooPrha4FkV6nNC9DQefzC0picHXV64oYUjMM2ed4ASTQVds7HP9BZfalz//APZcWdBV08f+xv7n79Twz/gNtVAadfuTAlcjsS6aK+G/OrZtr/diuemeRPRUKlVhcr5xOQDhqBgtdIw8M9Wp6I4ULXRlthKVBWToH9j6n9vDIiwIDAQAB", requestMes); } // 商城支付回调 public string NoticePay() { StreamReader sr = new StreamReader(Request.Body); string requestMes = sr.ReadToEnd(); function.WriteLog(DateTime.Now.ToString() + "\r\n" + requestMes + "\r\n\r\n", "支付宝支付回调2"); return PayCallBack2("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnw14hKejqS+si/XZpNQpFAVOVXJIThj5Qn7H14n/vsb7uRLug1+Jcve8ehTkaN3s5ibrrELCnz0dvshi3cOz9svDSbLG5OdC1biAvZzpDkvVPswOd9f9jO8Jvqk3QTXTI3MSN9gOpKomI0te3qs5kkOQx6kRozzKjU/G//o/PbJCxpBxf/QNRV3XmCwJLZMBE7ukYqi1WO9Jra8jdczFKwrd/nhiKBKdupAtVVeKlylGD2i2YLkGAH1cLsPUN9DtzrXNblGXm2HK3l9SnMDjqnakiVdEQJTNYNpEiHaOJsVmPQL38nM6miz5wNd4gTchKzXPtoZWqto+eIvYaEA/KwIDAQAB", requestMes); } // public string test() // { // string requestMes = "gmt_create=2022-03-30+12%3A06%3A39&charset=utf-8&seller_email=kexiaoshaung%40163.com&subject=%E5%BC%80%E5%BA%97%E5%AE%9D%E7%94%B5%E7%AD%BE&sign=vdGlzDoCNwidgdpH7xgRdCF%2BcSqDx%2Fm8dS7vZy%2BtMjQ7wr10KtbcjKgMRwW3fBclWWJjwisv28JD10Ejrvzjq5PCNbWhgD%2F0IuAkVeL%2FHsd0fTS7JZ8nQJPHBTCu42s0BREZEgf%2FY9gT23G7xIOpkw%2FWdcJYNo3rQyt%2Bcu380tY0KpghJBz2N06fow9vSjZLP7UmJQ%2FXe7uuIZvHvWRr61q%2FGRhewSgrhll1JvTVPu3c8mn3dFtAsiQJLrzFKfE0btroXOPqWqxjjmp5Ve0d0Cisdpa%2B9buRiuaADtxkVdFiI8TIDCFRkwmgnPqPQ6c93fxrstLYBJW4ntHVFRQEmw%3D%3D&body=%E5%BC%80%E5%BA%97%E5%AE%9D%E7%94%B5%E7%AD%BE&buyer_id=2088032351438405&invoice_amount=600.00¬ify_id=2022033000222120640038401447445102&fund_bill_list=%5B%7B%22amount%22%3A%22600.00%22%2C%22fundChannel%22%3A%22PCREDIT%22%7D%5D¬ify_type=trade_status_sync&trade_status=TRADE_SUCCESS&receipt_amount=600.00&app_id=2021003122642236&buyer_pay_amount=600.00&sign_type=RSA2&seller_id=2088141704579033&gmt_payment=2022-03-30+12%3A06%3A40¬ify_time=2022-03-30+12%3A06%3A40&version=1.0&out_trade_no=BM2022033012054623271756674&total_amount=600.00&trade_no=2022033022001438401438676038&auth_app_id=2021003122642236&buyer_logon_id=189****0372&point_amount=0.00"; // return PayCallBack2("MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxycehrmnTl2IaIAECP+0HWc1eWGM/T6x022K7K6fdf+xoyC97TBJaG4G3Bcon4gsJX+Sad5IA9OJIQ4eN1joM35hIlwcFZ6MmCuVXx/SMAKThIjK0jsRc6aTxVQG+GVCgS7dXMKb4Sm+vK2wEM6xtDeqcfYMB0BqGZRvxbIV59a2ooPrha4FkV6nNC9DQefzC0picHXV64oYUjMM2ed4ASTQVds7HP9BZfalz//APZcWdBV08f+xv7n79Twz/gNtVAadfuTAlcjsS6aK+G/OrZtr/diuemeRPRUKlVhcr5xOQDhqBgtdIw8M9Wp6I4ULXRlthKVBWToH9j6n9vDIiwIDAQAB", requestMes); // } public string PayCallBack(string publickey, string requestMes, bool IsRedis = false) { // Library.function.WriteLog(requestMes, "支付宝回调日志"); var result = "fail"; var sPara = GetRequestPost(requestMes); if (sPara.Count > 0) //判断是否有带返回参数 { // Library.function.WriteLog("有参数", "支付宝回调日志"); bool verifyResult = false; var aliNotify = new Com.Alipay.Notify(); string signtype = sPara["sign_type"]; var total_fee = 0m; string strPrice = sPara["total_amount"];//金额 decimal.TryParse(strPrice, out total_fee); verifyResult = AlipaySignature.RSACheckV1(sPara, publickey, "UTF-8", signtype, false); // Library.function.WriteLog(verifyResult.ToString(), "支付宝回调日志"); if (verifyResult) //验证成功 { // Library.function.WriteLog("验证成功\r\n\r\n", "支付宝回调日志"); //商户订单号 string out_trade_no = sPara["out_trade_no"]; //支付宝交易号 string trade_no = sPara["trade_no"]; //交易状态 TRADE_SUCCESS string trade_status = sPara["trade_status"]; //交易成功 if (trade_status == "TRADE_FINISHED" || trade_status == "TRADE_SUCCESS") { RedisDbconn.Instance.AddList("PayCallBack", "{\"out_trade_no\":\"" + out_trade_no + "\",\"transaction_id\":\"" + trade_no + "\",\"total_fee\":\"" + total_fee + "\",\"pay_mode\":\"1\",\"openid\":\"\",\"attach\":\"\"}"); result = "success"; } } } return result; } public string PayCallBack2(string publickey, string requestMes, bool IsRedis = false) { // Library.function.WriteLog(requestMes, "支付宝回调日志"); var result = "fail"; var sPara = GetRequestPost(requestMes); if (sPara.Count > 0) //判断是否有带返回参数 { // Library.function.WriteLog("有参数", "支付宝回调日志"); bool verifyResult = false; var aliNotify = new Com.Alipay.Notify(); string signtype = sPara["sign_type"]; var total_fee = 0m; string strPrice = sPara["total_amount"];//金额 decimal.TryParse(strPrice, out total_fee); verifyResult = AlipaySignature.RSACheckV1(sPara, publickey, "UTF-8", signtype, false); // Library.function.WriteLog(verifyResult.ToString(), "支付宝回调日志"); if (verifyResult) //验证成功 { // Library.function.WriteLog("验证成功\r\n\r\n", "支付宝回调日志"); //商户订单号 string out_trade_no = sPara["out_trade_no"]; //支付宝交易号 string trade_no = sPara["trade_no"]; //交易状态 TRADE_SUCCESS string trade_status = sPara["trade_status"]; //交易成功 if (trade_status == "TRADE_FINISHED" || trade_status == "TRADE_SUCCESS") { RedisDbconn.Instance.AddList("PayCallBack2", "{\"out_trade_no\":\"" + out_trade_no + "\",\"transaction_id\":\"" + trade_no + "\",\"total_fee\":\"" + total_fee + "\",\"pay_mode\":\"1\",\"openid\":\"\",\"attach\":\"\"}"); result = "success"; } } } return result; } private SortedDictionary GetRequestPost(string canshu) { var sArray = new SortedDictionary(); string[] canshulist = canshu.Split('&'); foreach (var substring in canshulist) { string[] datalist = substring.Split('='); sArray.Add(datalist[0], HttpUtility.UrlDecode(datalist[1])); } return sArray; } #endregion } }