ValveControlJob.cs 8.5 KB

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