MerchantConfirmService.cs 8.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using MySystem.Models;
  5. using Library;
  6. using LitJson;
  7. namespace MySystem
  8. {
  9. public class MerchantConfirmService
  10. {
  11. public readonly static MerchantConfirmService Instance = new MerchantConfirmService();
  12. private MerchantConfirmService()
  13. { }
  14. public void Start(string MerchantIdString)
  15. {
  16. try
  17. {
  18. int MerchantId = int.Parse(function.CheckInt(MerchantIdString));
  19. WebCMSEntities db = new WebCMSEntities();
  20. MerchantAddInfo AddInfo = db.MerchantAddInfo.FirstOrDefault(m => m.Id == MerchantId);
  21. MerchantInfo merchant = db.MerchantInfo.FirstOrDefault(m => m.Id == MerchantId);
  22. if (AddInfo != null && merchant != null)
  23. {
  24. string BusinessCode = AddInfo.BusinessCode;
  25. if (string.IsNullOrEmpty(BusinessCode))
  26. {
  27. BusinessCode = "KXS" + DateTime.Now.ToString("yyyyMMddHHmmssfff") + function.get_Random(5);
  28. AddInfo.BusinessCode = BusinessCode;
  29. db.SaveChanges();
  30. }
  31. List<MerchantInfo> merchants = TendisDbconn.Instance.GetList<MerchantInfo>("MerchantList:" + merchant.UserId, 1, 10000000);
  32. //微信
  33. string result = new WeChatFunction().MerchantCreate(AddInfo, merchant);
  34. if (result.Contains("\"applyment_id\":"))
  35. {
  36. JsonData jsonObj = JsonMapper.ToObject(result);
  37. AddInfo.ApplymentId = jsonObj["applyment_id"].ToString();
  38. db.SaveChanges();
  39. List<MerchantSign> signs = TendisDbconn.Instance.GetList<MerchantSign>("MerchantSignList", 1, 10000000);
  40. bool op = signs.Any(m => m.BusinessCode == BusinessCode);
  41. if (!op)
  42. {
  43. TendisDbconn.Instance.AddList("WeChatSignList", new MerchantSign()
  44. {
  45. BusinessCode = BusinessCode,
  46. MerchantAddInfoId = MerchantId,
  47. Status = ""
  48. });
  49. }
  50. signs.Clear();
  51. if (merchants.Any(m => m.Id == merchant.Id) == false)
  52. {
  53. BothdisDbconn.Instance.AddList("MerchantList:" + merchant.UserId, merchant);
  54. }
  55. }
  56. else if (result.Contains("\"message\":"))
  57. {
  58. JsonData jsonObj = JsonMapper.ToObject(result);
  59. AddInfo.Status = -1;
  60. string Season = function.CheckNull(AddInfo.SeoDescription);
  61. if (string.IsNullOrEmpty(Season))
  62. {
  63. Season = "WeChat:" + jsonObj["message"].ToString() + ";";
  64. }
  65. else
  66. {
  67. Season += "WeChat:" + jsonObj["message"].ToString()+ ";";
  68. }
  69. AddInfo.SeoDescription = Season;
  70. db.SaveChanges();
  71. if (merchants.Any(m => m.Id == merchant.Id) == false)
  72. {
  73. BothdisDbconn.Instance.AddList("MerchantList:" + merchant.UserId, merchant);
  74. }
  75. List<MerchantSign> signs = TendisDbconn.Instance.GetList<MerchantSign>("WeChatSignList", 1, 10000000);
  76. MerchantSign sign = signs.FirstOrDefault(m => m.BusinessCode == BusinessCode);
  77. if (sign != null)
  78. {
  79. signs.Remove(sign);
  80. TendisDbconn.Instance.Clear("WeChatSignList");
  81. TendisDbconn.Instance.AddList("WeChatSignList", signs.ToArray());
  82. }
  83. }
  84. //支付宝
  85. bool checkAlipay = true;
  86. string content = new AlipayFunction().GetBatchNo(AddInfo.CreateMan, AddInfo.IdCardName, AddInfo.MobilePhone, AddInfo.ContactEmail);
  87. JsonData json = JsonMapper.ToObject(content);
  88. if (json["alipay_open_agent_create_response"]["code"].ToString() == "1000")
  89. {
  90. string batch_no = json["alipay_open_agent_create_response"]["batch_no"].ToString();
  91. string Qualifications = AddInfo.Qualifications;
  92. if (!string.IsNullOrEmpty(Qualifications))
  93. {
  94. Qualifications = function.getPath("/bsserver_com" + Qualifications);
  95. }
  96. content = new AlipayFunction().CommonSign(batch_no, AddInfo.UpdateMan, AddInfo.LicenseNumber, function.getPath("/bsserver_com" + AddInfo.LicenseCopy), Qualifications);
  97. json = JsonMapper.ToObject(content);
  98. if (json["alipay_open_agent_common_sign_response"]["code"].ToString() == "1000")
  99. {
  100. List<MerchantSign> signs = TendisDbconn.Instance.GetList<MerchantSign>("MerchantSignList", 1, 10000000);
  101. bool op = signs.Any(m => m.BusinessCode == batch_no);
  102. if (!op)
  103. {
  104. TendisDbconn.Instance.AddList("AlipaySignList", new MerchantSign()
  105. {
  106. BusinessCode = batch_no,
  107. MerchantAddInfoId = MerchantId,
  108. Status = ""
  109. });
  110. }
  111. signs.Clear();
  112. if (merchants.Any(m => m.Id == merchant.Id) == false)
  113. {
  114. BothdisDbconn.Instance.AddList("MerchantList:" + merchant.UserId, merchant);
  115. }
  116. }
  117. else
  118. {
  119. checkAlipay = false;
  120. }
  121. }
  122. else
  123. {
  124. checkAlipay = false;
  125. }
  126. if(!checkAlipay)
  127. {
  128. JsonData jsonObj = JsonMapper.ToObject(content);
  129. AddInfo.QueryCount = -1;
  130. string Season = function.CheckNull(AddInfo.SeoDescription);
  131. if (string.IsNullOrEmpty(Season))
  132. {
  133. Season = "Alipay:" + jsonObj["alipay_open_agent_create_response"]["sub_msg"].ToString() + ";";
  134. }
  135. else
  136. {
  137. Season = "Alipay:" + jsonObj["alipay_open_agent_create_response"]["sub_msg"].ToString()+ ";" + Season;
  138. }
  139. AddInfo.SeoDescription = Season;
  140. db.SaveChanges();
  141. if (merchants.Any(m => m.Id == merchant.Id) == false)
  142. {
  143. BothdisDbconn.Instance.AddList("MerchantList:" + merchant.UserId, merchant);
  144. }
  145. List<MerchantSign> signs = TendisDbconn.Instance.GetList<MerchantSign>("AliaySignList", 1, 10000000);
  146. MerchantSign sign = signs.FirstOrDefault(m => m.BusinessCode == BusinessCode);
  147. if (sign != null)
  148. {
  149. signs.Remove(sign);
  150. TendisDbconn.Instance.Clear("AliaySignList");
  151. TendisDbconn.Instance.AddList("AliaySignList", signs.ToArray());
  152. }
  153. }
  154. }
  155. db.Dispose();
  156. }
  157. catch (Exception ex)
  158. {
  159. TendisDbconn.Instance.AddList("public_service", DateTime.Now.ToString() + ":" + ex.ToString());
  160. }
  161. }
  162. }
  163. }