KunshanPayCostSmsJob.cs 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. using Newtonsoft.Json;
  2. using Quartz;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Collections.Specialized;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using Utils;
  10. namespace PMS.NetCore.Service
  11. {
  12. /// <summary>
  13. /// 昆山项目发缴费短信
  14. /// </summary>
  15. public class KunshanPayCostSmsJob : IJob
  16. {
  17. NLog.Logger logger = NLog.LogManager.GetCurrentClassLogger();
  18. public Task Execute(IJobExecutionContext context)
  19. {
  20. return Task.Run(() =>
  21. {
  22. try
  23. {
  24. var thisDate = DateTime.Now.ToString("yyyy-MM-dd");
  25. //thisDate = "2020-12-01";
  26. //NlogHelper.quartzLogger.Info("开始");
  27. var sql = $" SELECT b.billitemname ,a.nneedpaymny ,a.nrevmny ,a.dneeddate,a.dbegindate,a.denddate,c.firsttel FROM fdc_pm_fare_b a INNER JOIN fdc_pm_billsitem b ON a.billitemcode=b.billitemcode INNER JOIN fdc_pm_owner c ON a.ownerid=c.ownerid WHERE ( a.flag=1 OR a.flag IS NULL) AND a.nneedpaymny>a.nrevmny AND CONVERT(VARCHAR(10),a.dneeddate,120)='{thisDate}' ";
  28. //logger.Info($"主项计划sql:{sql}");
  29. var manager = new actionsManager();
  30. var dt = manager.Db.Ado.GetDataTable(sql);
  31. for (int i = 0; i < dt.Rows.Count; i++)
  32. {
  33. //费用类型
  34. var billitemname = dt.Rows[i]["billitemname"]?.ToString();
  35. //手机号
  36. var phone = dt.Rows[i]["firsttel"]?.ToString();
  37. //应交日期
  38. var dneeddate = dt.Rows[i]["dneeddate"].ToString();
  39. //开始日期
  40. var dbegindate = dt.Rows[i]["dbegindate"]?.ToString();
  41. //结束日期
  42. var denddate = dt.Rows[i]["denddate"]?.ToString();
  43. ////1:租金,2:水费,3:电费,4:服务费,5:押保,6:违约金,7:创收,8:水电费,9:物业费
  44. var type = "";
  45. if(billitemname=="租金")
  46. {
  47. type = "1";
  48. }
  49. else if (billitemname == "水费")
  50. {
  51. type = "2";
  52. }
  53. else if (billitemname == "电费")
  54. {
  55. type = "3";
  56. }
  57. else if (billitemname == "服务费")
  58. {
  59. type = "4";
  60. }
  61. else if (billitemname == "押保")
  62. {
  63. type = "5";
  64. }
  65. else if (billitemname == "违约金")
  66. {
  67. type = "6";
  68. }
  69. else if (billitemname == "创收")
  70. {
  71. type = "7";
  72. }
  73. else if (billitemname == "水电费")
  74. {
  75. type = "8";
  76. }
  77. else if (billitemname == "物业费")
  78. {
  79. type = "9";
  80. }
  81. if(type.IsNotNullAndEmpty())
  82. {
  83. var closingDate = Convert.ToDateTime(dbegindate).ToString("yyyy年MM月") + "至" + Convert.ToDateTime(denddate).ToString("yyyy年MM月");
  84. var outingDate = Convert.ToDateTime(dneeddate).ToString("yyyy年MM月dd日");
  85. string url = AppSettingsHelper.Configuration["kunshanUrl"];
  86. var postvalues = new NameValueCollection();
  87. postvalues.Add("telephone", phone);
  88. postvalues.Add("type", type);
  89. postvalues.Add("closingDate", closingDate);
  90. postvalues.Add("outingDate", outingDate);
  91. var res = WebClientHelper.ClientPost(url, postvalues);
  92. NlogHelper.quartzLogger.Info($"手机号:{phone}发送短信执行完毕");
  93. var outData = JsonConvert.DeserializeObject<OutData>(res);
  94. sql = $"insert into sms(Phone,status,msg,contents) values ('{phone}','{outData.status}','{outData.msg}','{outData.contents}')";
  95. manager.Db.Ado.ExecuteCommand(sql);
  96. }
  97. }
  98. }
  99. catch (Exception ero)
  100. {
  101. NlogHelper.quartzLogger.Error(" 发邮件执行出错:" + ero, true);
  102. }
  103. });
  104. }
  105. }
  106. public class OutData
  107. {
  108. public string status { get; set; }
  109. public string msg { get; set; }
  110. public string contents { get; set; }
  111. }
  112. }