MerchantDepositOrderController.cs 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.Extensions.Options;
  8. using Microsoft.AspNetCore.Authorization;
  9. using System.Web;
  10. using MySystem.Models.Main;
  11. using LitJson;
  12. using Library;
  13. using System.Data;
  14. using MySystem.Service.Main;
  15. namespace MySystem.Areas.Api.Controllers.v1
  16. {
  17. [Area("Api")]
  18. [Route("/v1/qrcodeplatemain/[controller]/[action]")]
  19. public class MerchantDepositOrderController : BaseController
  20. {
  21. public MerchantDepositOrderController(IHttpContextAccessor accessor) : base(accessor)
  22. {
  23. }
  24. //AppId
  25. private string AppId = "2021004123675441";
  26. //私钥
  27. private string PrivateKey = "MIIEogIBAAKCAQEAn6vdQjedN72fPHtU1a1zSBvoYoyn9fIrjJhnJg4tGAVPk20I4AMiiKpgWn9cDAEgLddceYfR0IRWw+ojZZqVjJsLG8D715H4xJ6AnllWyeNJd43CdTctTnXRAl25Cw2SuG1kanAA/BO186J2LyN/z7l70LkxOFUJVHXhTx0sKxAS7ZBA43ewjl7ycp108eNNbR63gLjy4VDP63pOnI4MuTNeXh3ET/eunREs8gGuvdXOfY9r2Dyj9lOiOPn1xyrZPpT+WGXrPxLyWnSAz1EkLx7d2aRPFFC1rwJQbcsdBnmN35d6hbofOOe9kPN23Z34d0X6ohD0VbiUUdpzU4f9ZwIDAQABAoIBAFK+U3i/LT/3ig9jskDRE86od7KqRVgU2TCQwdNcwU2TYvt5I4JC3aCI+kmrel3WL4DR++AW3En8aqI4MYOzqhAlQIpvZZL+2DW8Fdb5YRpaKHZGBiGMKHRiZZ+eRghOTlw4hDMMO9ZluIK7DBe9g7x32Iv/jFwu5RjZxZqj+YGOjnMTQvXdrHc5WH7nI9bJC4EJUD1WsO5wmgHkdwPLSKAPLoc+PcCD8manlq2XU560TycZJmaXhBNtkAwlhhu8tY/hPsbQBMwIN8VtWiE0sD0fgR8r0Hq3yLxG1ysXQfrL105UC6+6Srxz17MmcS/beIPvFUSu0GHYgeHHKc1FnVECgYEA3ZtDhG/e7/hCKWW3xAKse+xJ77T3lSxH9HP4Shh6fEaKefFx+aN3VddpAEJpt7w0WbxJTduwD0gtu3IY9XCIX8mJPMk/Thy14MI/VTynJheK2zGylPep4MF6nXP3QfBfgN+Kq/XYHTWZK7gD2vfgHjGKuAW7fHQLLhMjNZ3/o3UCgYEAuHPUiZueKXYIZ7hPdNvChb9UKQdyrx9SVS8gQph4uAbHmNT1caVyvdmWSOYP3h2/UnJ8dCGAEBzd1CFlf959jzT7uceabZXOLtgTKa8qfJfvM4a5uTfr7XxUfcJgQzaugAqXwl4Wiwe0Y8DrWudo+Umb5MvpfQCXQVpIBBJQDesCgYA2mXGKKNIBx+XtMy2SsqHyqmYRFEJH07Aqz4PmJZ/QDMVDhDRzsE3PrZImSTao2UsArP5Wm4EGUt9JprP1jPNcvlf8zQy23yYEqXdXNels3jINDXKVd2u4f5MJRjAuY93z75/H/HtxvuntNppkkdv7NHOcIXVvFVxHztlG9ZWtnQKBgB2OwjJC87dlKLemO2VYifVw0YW5odEaTdFEugCx+jZTL8z341UQ1DBEG+cWpthLIAuQOQ1LCQCL/6gsqd0xxCEctnHw4HhLFz0+duOpJD/PAQ/auQxLP81QrSFx8ocSzifKisMk3Kvu0iNiGNT6XEIGX6rsWkAjxhk85Glync19AoGAazxVqVo3SMOzfAZHxvYWu81asFDN7+wvnOhUwWM+BOIYrhd4rspmQ691tOPQSAsXFXeFOmVtJDguRp0TtnysFVTH2goljCvc9WTuBLjUlj/g0hyBNQA5bBItdvlA1aRhYQSa1yhGK3IGcCYW6agkDhb8LdLZMlEsTcEpkOLoSmQ=";
  28. // 公钥
  29. private string PublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAn6vdQjedN72fPHtU1a1zSBvoYoyn9fIrjJhnJg4tGAVPk20I4AMiiKpgWn9cDAEgLddceYfR0IRWw+ojZZqVjJsLG8D715H4xJ6AnllWyeNJd43CdTctTnXRAl25Cw2SuG1kanAA/BO186J2LyN/z7l70LkxOFUJVHXhTx0sKxAS7ZBA43ewjl7ycp108eNNbR63gLjy4VDP63pOnI4MuTNeXh3ET/eunREs8gGuvdXOfY9r2Dyj9lOiOPn1xyrZPpT+WGXrPxLyWnSAz1EkLx7d2aRPFFC1rwJQbcsdBnmN35d6hbofOOe9kPN23Z34d0X6ohD0VbiUUdpzU4f9ZwIDAQAB";
  30. // 支付宝公钥
  31. private string AlipayPublicKey = "MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAnw14hKejqS+si/XZpNQpFAVOVXJIThj5Qn7H14n/vsb7uRLug1+Jcve8ehTkaN3s5ibrrELCnz0dvshi3cOz9svDSbLG5OdC1biAvZzpDkvVPswOd9f9jO8Jvqk3QTXTI3MSN9gOpKomI0te3qs5kkOQx6kRozzKjU/G//o/PbJCxpBxf/QNRV3XmCwJLZMBE7ukYqi1WO9Jra8jdczFKwrd/nhiKBKdupAtVVeKlylGD2i2YLkGAH1cLsPUN9DtzrXNblGXm2HK3l9SnMDjqnakiVdEQJTNYNpEiHaOJsVmPQL38nM6miz5wNd4gTchKzXPtoZWqto+eIvYaEA/KwIDAQAB";
  32. #region 商户激活-确认支付
  33. // [Authorize]
  34. public JsonResult Pay(string value)
  35. {
  36. value = DesDecrypt(value);
  37. JsonData data = JsonMapper.ToObject(value);
  38. AppResultJson result = PayDo(value);
  39. return Json(new AppResultJson() { Status = result.Status, Info = result.Info, Data = result.Data });
  40. }
  41. public AppResultJson PayDo(string value)
  42. {
  43. JsonData data = JsonMapper.ToObject(value);
  44. int PayMode = int.Parse(function.CheckInt(data["PayMode"].ToString())); //支付方式(1 支付宝)
  45. int MerchantId = int.Parse(function.CheckInt(data["MerchantId"].ToString())); //商户Id
  46. int Id = int.Parse(function.CheckInt(data["Id"].ToString())); //订单记录Id
  47. Dictionary<string, object> Obj = new Dictionary<string, object>();
  48. var query = MerchantDepositOrderService.Query(Id);
  49. if (query.Id > 0)
  50. {
  51. Dictionary<string, object> fields = new Dictionary<string, object>();
  52. fields.Add("Sort", PayMode); //支付方式(1 支付宝)
  53. MerchantDepositOrderService.Edit(fields, Id, false);
  54. string PayData = "";
  55. Models.KxsMainModels.PublicAccountSet set = new AlipayFunctionForKxs(_accessor.HttpContext).SetData(MerchantId);
  56. if (PayMode == 1)
  57. {
  58. string TotalPrice = query.ActPayPrice.ToString();
  59. function.WriteLog(query.OrderNo, "支付宝支付日志");
  60. function.WriteLog(TotalPrice.ToString(), "支付宝支付日志");
  61. function.WriteLog("商户激活—确认订单", "支付宝支付日志");
  62. string ProductName = "商户激活";
  63. PayData = new Alipay.AlipayPublicClass(_accessor.HttpContext).GetAlipayInfo(query.OrderNo, TotalPrice, ProductName, set.AlipayAppId, set.AlipayPrivateKey, SpHost + "/Api/Alipay/NoticePay");
  64. // PayData = new Alipay.AlipayPublicClass(_accessor.HttpContext).GetAlipayInfo(query.OrderNo, TotalPrice, ProductName, AppId, PrivateKey, SpHost + "/Api/Alipay/NoticePay2");
  65. function.WriteLog(PayData, "支付宝支付日志");
  66. }
  67. Obj.Add("PayData", PayData); //支付宝微信SDK所需数据
  68. }
  69. return new AppResultJson() { Status = "1", Info = "", Data = Obj };
  70. }
  71. #endregion
  72. #region 商户激活—确认订单
  73. // [Authorize]
  74. public JsonResult ConfirmOrder(string value)
  75. {
  76. value = DesDecrypt(value);
  77. JsonData data = JsonMapper.ToObject(value);
  78. AppResultJson result = ConfirmOrderDo(value);
  79. return Json(new AppResultJson() { Status = result.Status, Info = result.Info, Data = result.Data });
  80. }
  81. public AppResultJson ConfirmOrderDo(string value)
  82. {
  83. function.WriteLog(value, "商户激活—确认订单");
  84. JsonData data = JsonMapper.ToObject(value);
  85. int MerchantId = int.Parse(function.CheckInt(data["MerchantId"].ToString())); //商户Id
  86. Dictionary<string, object> Obj = new Dictionary<string, object>();
  87. MerchantInfo merchant = MerchantInfoService.Query(MerchantId);
  88. string OrderNo = "U" + DateTime.Now.ToString("yyyyMMddHHmmssfff") + function.get_Random(8);
  89. string check = RedisDbconn.Instance.Get<string>("ConfirmOrder:" + MerchantId + "_" + OrderNo);
  90. if (!string.IsNullOrEmpty(check))
  91. {
  92. return new AppResultJson() { Status = "-1", Info = "请勿重复下单!" };
  93. }
  94. RedisDbconn.Instance.Set("ConfirmOrder:" + MerchantId + "_" + OrderNo, "1");
  95. RedisDbconn.Instance.SetExpire("ConfirmOrder:" + MerchantId + "_" + OrderNo, 10);
  96. var IsBuy = MerchantDepositOrderService.Query(" 1=1 and Status>0 and MerchantId=" + MerchantId + "");
  97. if (IsBuy.Id > 0) return new AppResultJson() { Status = "-1", Info = "请勿重复下单!" };
  98. decimal ActPayPrice = 365; //服务费总额
  99. var Id = MerchantDepositOrderUtil.AddMerchantDepositOrder(OrderNo, merchant.UserId, MerchantId, ActPayPrice);
  100. var query = MerchantDepositOrderService.Query(Id);
  101. Obj.Add("Id", Id); //Id
  102. Obj.Add("CreateDate", query.CreateDate); //创建时间
  103. return new AppResultJson() { Status = "1", Info = "", Data = Obj };
  104. }
  105. #endregion
  106. #region 已激活商户-活动时间
  107. // [Authorize]
  108. public JsonResult Info(string value)
  109. {
  110. value = DesDecrypt(value);
  111. JsonData data = JsonMapper.ToObject(value);
  112. AppResultJson result = InfoDo(value);
  113. return Json(new AppResultJson() { Status = result.Status, Info = result.Info, Data = result.Data });
  114. }
  115. public AppResultJson InfoDo(string value)
  116. {
  117. JsonData data = JsonMapper.ToObject(value);
  118. int MerchantId = int.Parse(function.CheckInt(data["MerchantId"].ToString())); //商户Id
  119. Dictionary<string, object> Obj = new Dictionary<string, object>();
  120. var CreateDate = "";
  121. var StartDate = "";
  122. var EndDate = "";
  123. var Status = -1;
  124. var query = MerchantDepositOrderService.Query(" 1=1 and Status>0 and MerchantId=" + MerchantId + "");
  125. if (query.Id > 0)
  126. {
  127. CreateDate = DateTime.Parse(query.UpdateDate.ToString()).Year + "年" + DateTime.Parse(query.UpdateDate.ToString()).Month + "月" + DateTime.Parse(query.UpdateDate.ToString()).Day + "日";
  128. StartDate = DateTime.Parse(query.UpdateDate.ToString()).AddMonths(1).Year + "年" + DateTime.Parse(query.UpdateDate.ToString()).AddMonths(1).Month + "月";
  129. EndDate = DateTime.Parse(query.UpdateDate.ToString()).AddMonths(11).Year + "年" + DateTime.Parse(query.UpdateDate.ToString()).AddMonths(11).Month + "月";
  130. Status = MerchantInfoService.Query(MerchantId).ExamineStatus;
  131. }
  132. Obj.Add("CreateDate", CreateDate); //参与时间
  133. Obj.Add("StartDate", StartDate); //考核开始时间
  134. Obj.Add("EndDate", EndDate); //考核结束时间
  135. Obj.Add("Status", Status); //考核状态(-1 未参与 0 考核中 1 已通过 2 未通过 101 待领取 100 已领取 99 发放中)
  136. return new AppResultJson() { Status = "1", Info = "", Data = Obj };
  137. }
  138. #endregion
  139. }
  140. }