ValueControlJob.cs 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. using log4net;
  2. using Newtonsoft.Json.Linq;
  3. using Quartz;
  4. using RDIFramework.Utilities;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Data;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Net;
  11. using System.Text;
  12. using TimedUpload.WebReference;
  13. namespace TimedUpload.QuartzJobs
  14. {
  15. public class ValueControlJob : IJob
  16. {
  17. private readonly ILog log = LogManager.GetLogger(typeof(ValueControlJob));
  18. public void Execute(IJobExecutionContext context)
  19. {
  20. try
  21. {
  22. log.Info("控阀接口开始执行.................\r\n");
  23. //2021-12-24 开关控阀
  24. UpdateValveControl();
  25. }
  26. catch (Exception ex)
  27. {
  28. log.Error("任务上传异常:" + ex.Message);
  29. }
  30. log.InfoFormat("控阀接口执行结束.................\r\n");
  31. }
  32. #region 开关控阀
  33. private void UpdateValveControl()
  34. {
  35. String result;
  36. //远传表厂家编号
  37. String metersortId = "13";
  38. //远传水表阀控接口url
  39. String serviceAddress = "http://47.105.45.253:1943/WebServices/ExternalValueControlApi.ashx";
  40. // String serviceAddress = "http://localhost:2801/WebServices/ExternalValueControlApi.ashx";
  41. String Code = null;
  42. String Message = null;
  43. try
  44. {
  45. WebReference.MeterReadingImplService wm = new WebReference.MeterReadingImplService();
  46. valveControlList[] vcList = wm.ValveControl(metersortId);
  47. //测试
  48. /*result = postSend(serviceAddress, "");
  49. log.Debug("上传结果---------》" + "," + result);*/
  50. log.Debug("~~~~~~~~~~~开始下达开阀指令~~~~~~~~~~~~~");
  51. if (vcList != null)
  52. {
  53. StringBuilder valveControlInfo = new StringBuilder();
  54. foreach (var vc in vcList)
  55. {
  56. log.Debug("下载数据:" + vc.meteraddress + "," + vc.valveState + "," + vc.controlTime);
  57. valveControlInfo.Append("ManufacturerCode=6e50093a-2b74-4e3e-9993-c3bd1f23979a&");
  58. valveControlInfo.Append("MeterAddress=" + vc.meteraddress + "&");
  59. valveControlInfo.Append("CommandType=Valve&");
  60. //0 开阀 其他关阀
  61. //获取开阀或关阀指令
  62. if (vc.valveState=="0")
  63. {
  64. log.Debug("控阀指令---------》" + vc.meteraddress + "," + "开阀");
  65. valveControlInfo.Append("ValueState=open");
  66. vc.valveState = "0-开阀";
  67. }
  68. else
  69. {
  70. log.Debug("控阀指令---------》" + vc.meteraddress + "," + "关阀");
  71. valveControlInfo.Append("ValueState=close");
  72. vc.valveState = vc.valveState+"-关阀";
  73. }
  74. result = WebHelper.HttpWebRequest(serviceAddress, valveControlInfo.ToString());
  75. log.Debug("上传结果---------》" + vc.meteraddress + "," + result);
  76. String sql = "insert into TempValveControlData(id,meteraddress,valveState,updateTime,Message) values(" + vc.id + ",'" + vc.meteraddress + "','" + vc.valveState + "','" + vc.controlTime + "','" + result + "')";
  77. dbHelperNB.ExecuteNonQuery(sql);
  78. valveControlInfo.Clear();
  79. }
  80. }
  81. }
  82. catch (Exception ex)
  83. {
  84. log.Debug("上传数据失败:" + ex.ToString());
  85. }
  86. }
  87. #endregion
  88. #region 请求接口
  89. /// <summary>
  90. ///
  91. /// </summary>
  92. /// <param name="url"></param>
  93. /// <param name="param"></param>
  94. /// <param name="type"></param>
  95. /// <param name="webHeader">请求头携带请求权限</param>
  96. /// <returns></returns>
  97. public string postSend(string url, WebHeaderCollection webHeader, String param, String type = "POST")
  98. {
  99. string strResult = "";
  100. Encoding myEncode = Encoding.GetEncoding("UTF-8");
  101. HttpWebRequest req = (HttpWebRequest)HttpWebRequest.Create(url);
  102. req.Method = type;
  103. req.ContentType = "application/x-www-form-urlencoded";
  104. req.Headers = webHeader;
  105. //req.ContentLength = 100;
  106. if (param != null)
  107. {
  108. byte[] postBytes = Encoding.UTF8.GetBytes(param);
  109. req.ContentLength = postBytes.Length;
  110. using (Stream reqStream = req.GetRequestStream())
  111. {
  112. reqStream.Write(postBytes, 0, postBytes.Length);
  113. }
  114. }
  115. try
  116. {
  117. using (WebResponse res = req.GetResponse())
  118. {
  119. using (StreamReader sr = new StreamReader(res.GetResponseStream(), myEncode))
  120. {
  121. strResult = sr.ReadToEnd();
  122. return strResult;
  123. }
  124. }
  125. }
  126. catch (WebException ex)
  127. {
  128. log.Error("Post数据出错:" + ex.Message);
  129. return "";
  130. }
  131. }
  132. #endregion
  133. static IDbProvider dbHelperNB
  134. {
  135. get
  136. {
  137. var DbDefine = DbFactoryProvider.GetProvider(CurrentDbType.SqlServer, Constants.DBUrlNbYd);
  138. return DbDefine;
  139. }
  140. }
  141. }
  142. public class TempValveControlData
  143. {
  144. /// <summary>
  145. /// Id
  146. /// </summary>
  147. public Guid dataId { get; set; } = Guid.NewGuid();
  148. /// <summary>
  149. /// 指令编号
  150. /// </summary>
  151. public int id { get; set; }
  152. /// <summary>
  153. /// 表地址
  154. /// </summary>
  155. public String meteraddress { get; set; }
  156. /// <summary>
  157. /// 指令状态 0:开阀 其他 :关阀
  158. /// </summary>
  159. public String valveState { get; set; }
  160. /// <summary>
  161. /// 接口返回的结果
  162. /// </summary>
  163. public String Code { get; set; }
  164. /// <summary>
  165. /// 失败时返回具体错误原因
  166. /// </summary>
  167. public String Message { get; set; }
  168. /// <summary>
  169. /// 更新时间
  170. /// </summary>
  171. public DateTime updateTime { get; set; } = DateTime.Now;
  172. /// <summary>
  173. /// 逻辑删除
  174. /// </summary>
  175. public String isRemove { get; set; } = "false";
  176. }
  177. }