CheckWeChatSignService.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Data;
  5. using MySystem.Models.Main;
  6. using Library;
  7. using LitJson;
  8. using System.Text.RegularExpressions;
  9. using System.Threading;
  10. namespace MySystem
  11. {
  12. public class CheckWeChatSignService
  13. {
  14. public readonly static CheckWeChatSignService Instance = new CheckWeChatSignService();
  15. private CheckWeChatSignService()
  16. { }
  17. public void Start()
  18. {
  19. Thread th = new Thread(StartListen);
  20. th.IsBackground = true;
  21. th.Start();
  22. }
  23. public void StartListen()
  24. {
  25. while (true)
  26. {
  27. // string content = RedisDbconn.Instance.RPop<string>("WeChatSignHdQueue");
  28. // if (!string.IsNullOrEmpty(content))
  29. // {
  30. // if (content == "sleep")
  31. // {
  32. // RedisDbconn.Instance.AddList("WeChatSignHdQueue", "sleep");
  33. // Thread.Sleep(60000);
  34. // }
  35. // else
  36. // {
  37. // QueryMerchantStatus queryMerchantStatus = Newtonsoft.Json.JsonConvert.DeserializeObject<QueryMerchantStatus>(content);
  38. // string result = StartDo(queryMerchantStatus);
  39. // if (result == "wait")
  40. // {
  41. // Thread.Sleep(500);
  42. // RedisDbconn.Instance.AddList("WeChatSignHdQueue", queryMerchantStatus);
  43. // }
  44. // }
  45. // }
  46. // else
  47. // {
  48. // Thread.Sleep(2000);
  49. // }
  50. DataTable dt = CustomerSqlConn.dtable("select Id,MchtNo from MerchantAddInfo where Id in (select Id from MerchantInfo where Sort=1 and `Status`=0 and QueryCount=0) and MchtNo!='' and MchtNo is not null", AppConfig.Base.SqlConnStr);
  51. foreach (DataRow dr in dt.Rows)
  52. {
  53. StartDo(new QueryMerchantStatus()
  54. {
  55. MerchantId = dr["Id"].ToString(),
  56. MerchantNo = dr["MchtNo"].ToString(),
  57. });
  58. Thread.Sleep(10000);
  59. }
  60. if(Library.ConfigurationManager.EnvironmentFlag == 2)
  61. {
  62. Thread.Sleep(300000);
  63. }
  64. else
  65. {
  66. Thread.Sleep(3600000);
  67. }
  68. }
  69. }
  70. public string StartDo(QueryMerchantStatus query)
  71. {
  72. try
  73. {
  74. var mId = int.Parse(query.MerchantId);
  75. WebCMSEntities db = new WebCMSEntities();
  76. MerchantAddInfo merchantadd = db.MerchantAddInfo.FirstOrDefault(m => m.Id == mId);
  77. var BrhCode = HaodaUnionParam.BrhCode;
  78. if (merchantadd.BrandId == 1) BrhCode = HaodaParam.BrhCode;
  79. //查询商户审核状态
  80. var returnInfo = HaoDaHelper.Instance.QueryMerchantStatus(BrhCode, query.MerchantNo, merchantadd.BrandId);
  81. JsonData dic = JsonMapper.ToObject(returnInfo);
  82. //审核成功(1- 待审核 2 -审核中 3 -审核被拒绝 4 -审核通过 6 -待复核)
  83. if (dic["data"]["code"].ToString() == "4" && !string.IsNullOrEmpty(dic["data"]["storeNo"].ToString()) && !string.IsNullOrEmpty(dic["data"]["outMchtNo"].ToString()))
  84. {
  85. //查询商户是否存在
  86. if (merchantadd != null)
  87. {
  88. MerchantInfo merchant = db.MerchantInfo.FirstOrDefault(m => m.Id == mId);
  89. merchantadd.StoreNo = dic["data"]["storeNo"].ToString();
  90. merchantadd.HdStatus = 1; //0 待审核 1 已通过 2 已开通分账 3 已添加接收方
  91. merchantadd.OutMchtNo = dic["data"]["outMchtNo"].ToString();
  92. if (merchantadd.BrandId == 1)
  93. {
  94. merchantadd.Status = 2;
  95. merchantadd.QueryCount = 2;
  96. merchant.Status = 2;
  97. merchant.QueryCount = 2;
  98. }
  99. else
  100. {
  101. if (merchant != null)
  102. {
  103. merchant.Status = 1;
  104. }
  105. //商户开通分账
  106. JsonData Info = JsonMapper.ToObject(HaoDaHelper.Instance.OpenDivideAccounts(merchantadd.OutMchtNo, merchantadd.StoreNo, merchantadd.BrandId));
  107. //开通失败
  108. if (Info["resultCode"].ToString() == "0")
  109. {
  110. merchantadd.Status = -1;
  111. merchantadd.WeChatRemark = Info["errorDesc"].ToString();
  112. }
  113. //开通成功
  114. if (Info["resultCode"].ToString() == "1")
  115. {
  116. merchantadd.OpenAct = 1;//是否开通分账(1 是 0 否)
  117. merchantadd.HdStatus = 2; //0 待审核 1 已通过 2 已开通分账 3 已添加接收方
  118. //分账接收方签约
  119. JsonData Infos = JsonMapper.ToObject(HaoDaHelper.Instance.DivideAccountsSign(AppConfig.Haoda.AcctNo, merchantadd.OutMchtNo, merchantadd.StoreNo, merchantadd.BrandId));
  120. //失败
  121. if (Infos["resultCode"].ToString() == "0")
  122. {
  123. merchantadd.WeChatRemark = Infos["errorDesc"].ToString();
  124. }
  125. //成功
  126. else
  127. {
  128. merchantadd.HdStatus = 3; //0 待审核 1 已通过 2 已开通分账 3 已添加接收方
  129. if (!string.IsNullOrEmpty(merchantadd.ToAcctNo))
  130. {
  131. if (!merchantadd.ToAcctNo.Contains("," + AppConfig.Haoda.AcctNo + ","))
  132. {
  133. merchantadd.ToAcctNo += "," + AppConfig.Haoda.AcctNo + ",";
  134. }
  135. }
  136. else
  137. {
  138. merchantadd.ToAcctNo += "," + AppConfig.Haoda.AcctNo + ",";
  139. }
  140. merchantadd.HdPassDate = DateTime.Now;
  141. }
  142. }
  143. //开户意愿申请
  144. RedisDbconn.Instance.AddList("AlipayForHaoDaQueue", mId);
  145. RedisDbconn.Instance.AddList("WeChatForHaoDaQueue", mId);
  146. }
  147. db.SaveChanges();
  148. //创客账号
  149. Models.Main1.WebCMSEntities db1 = new Models.Main1.WebCMSEntities();
  150. string pwd = merchantadd.MobilePhone.Substring(5);
  151. merchant.LoginPwd = function.MD532(pwd);
  152. Models.Main1.MerchantLoginInfo info = db1.MerchantLoginInfo.FirstOrDefault(m => m.LoginMobile == merchantadd.MobilePhone);
  153. if (info == null)
  154. {
  155. info = db1.MerchantLoginInfo.Add(new Models.Main1.MerchantLoginInfo()
  156. {
  157. LoginMobile = merchantadd.MobilePhone,
  158. }).Entity;
  159. db1.SaveChanges();
  160. }
  161. info.LoginPwd = function.MD532(pwd);
  162. db1.SaveChanges();
  163. Models.Main1.MerchantAccountLinkInfo infolink = db1.MerchantAccountLinkInfo.FirstOrDefault(m => m.LoginId == info.Id && m.MerchantId == merchantadd.Id && m.Kind == 2);
  164. if (infolink == null)
  165. {
  166. infolink = db1.MerchantAccountLinkInfo.Add(new Models.Main1.MerchantAccountLinkInfo()
  167. {
  168. LoginId = info.Id,
  169. MerchantId = merchantadd.Id,
  170. Kind = 2,
  171. }).Entity;
  172. db1.SaveChanges();
  173. }
  174. db1.Dispose();
  175. if (merchantadd.BrandId == 1)
  176. {
  177. SortedList<string, string> obj = new SortedList<string, string>();
  178. obj.Add("bind_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  179. obj.Add("merch_no", merchantadd.MchtNo);
  180. obj.Add("name", merchantadd.CertMerchantName);
  181. string IdCardNumber = merchantadd.IdCardNumber;
  182. if(!string.IsNullOrEmpty(IdCardNumber))
  183. {
  184. IdCardNumber = IdCardNumber.Substring(0, 6) + "**********" + IdCardNumber.Substring(IdCardNumber.Length - 4);
  185. }
  186. obj.Add("supplement_info", IdCardNumber);
  187. obj.Add("mobile", merchantadd.MobilePhone);
  188. PushHelper.Instance.Do(obj);
  189. }
  190. }
  191. }
  192. //审核被拒绝
  193. else if (dic["data"]["code"].ToString() == "3")
  194. {
  195. if (merchantadd != null)
  196. {
  197. string WeChatRemark = dic["data"]["option"].ToString();
  198. if (WeChatRemark.Contains("租赁协议") && WeChatRemark.Contains("水电煤") && WeChatRemark.Contains("门头合影") && WeChatRemark.Contains("下载地址"))
  199. {
  200. WeChatRemark = "门头不一致需补充 “名称不一致说明函”";
  201. }
  202. if (WeChatRemark.Contains("盒伙人在门头合影"))
  203. {
  204. WeChatRemark = "门头不一致需补充 “名称不一致说明函”";
  205. }
  206. if (WeChatRemark.Contains("不支持跨商户进件"))
  207. {
  208. WeChatRemark = "该商户已注册,错误指令【404】";
  209. }
  210. merchantadd.WeChatRemark = WeChatRemark;
  211. merchantadd.Status = -1;
  212. MerchantInfo merchant = db.MerchantInfo.FirstOrDefault(m => m.Id == mId);
  213. if (merchant != null)
  214. {
  215. merchant.Status = -1;
  216. }
  217. db.SaveChanges();
  218. }
  219. }
  220. else
  221. {
  222. return "wait";
  223. }
  224. }
  225. catch (Exception ex)
  226. {
  227. LogHelper.Instance.WriteLog(DateTime.Now.ToString() + ":" + ex.ToString(), "好哒商户进件状态查询异常");
  228. }
  229. return "";
  230. }
  231. }
  232. }