PingNetwork.cs 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. using com.hnshituo.core.webapp.vo;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Net.NetworkInformation;
  7. using System.Text;
  8. using System.Threading;
  9. using System.Threading.Tasks;
  10. namespace RailLocalMeter
  11. {
  12. public class PingNetwork
  13. {
  14. Log lg = Log.GetInstance();
  15. private bool blThreadFlag = true;
  16. Thread DataCollectThread = null;//采集进程
  17. string dbFile = Path.Combine(AppConfigCache.path, "data/rfidDb.data");
  18. MeterBaseRfidInfoService rfidServer = new MeterBaseRfidInfoService();
  19. public PingNetwork()
  20. {
  21. DataCollectThread = new Thread(new ThreadStart(DataCollect));
  22. }
  23. public void start()
  24. {
  25. DataCollectThread.Start();
  26. }
  27. public void stop()
  28. {
  29. blThreadFlag = false;
  30. }
  31. private void DataCollect()
  32. {
  33. if (!blThreadFlag) return;
  34. while (blThreadFlag)
  35. {
  36. try
  37. {
  38. Ping pingSend = new Ping();
  39. PingReply reply = pingSend.Send(AppConfigCache.ServiceIp, 1000);
  40. if (reply.Status == IPStatus.Success)
  41. CacleCls.serverFlag = true;
  42. else
  43. CacleCls.serverFlag = false;
  44. }
  45. catch (Exception)
  46. {
  47. CacleCls.serverFlag = false;
  48. }
  49. finally
  50. {
  51. if (CacleCls.serverFlag)
  52. {
  53. if (CacleCls.weight < 500 && DateTime.Now > CacleCls.updateRfidInfoTime)
  54. {
  55. CacleCls.updateRfidInfoTime.Value.AddHours(1); //每隔一小时更新一次rfid数据
  56. Dictionary<string, string> rfidInfo = new Dictionary<string, string>();
  57. RESTfulResult<List<MeterBaseRfidInfo>> rfids = rfidServer.doQueryRfid(new MeterBaseRfidInfo { valueFlag = "0" });
  58. if (rfids.Succeed)
  59. {
  60. if (rfids.Data != null && rfids.Data.Count > 0)
  61. {
  62. StringBuilder sb = new StringBuilder();
  63. foreach (MeterBaseRfidInfo rfid in rfids.Data)
  64. {
  65. try
  66. {
  67. sb.AppendLine($"{rfid.rfidCode},{rfid.carNo}");
  68. rfidInfo.Add(rfid.rfidCode, rfid.carNo);
  69. }
  70. catch { }
  71. }
  72. try
  73. {
  74. //如果目标文件存在则覆盖,不存在则创建
  75. File.WriteAllText(dbFile, sb.ToString());
  76. }
  77. catch (Exception ex)
  78. {
  79. lg.WriteLog(LogType.SystemLog, "写入rfid数据到本地失败:" + ex.Message);
  80. }
  81. CacleCls.rifdInfo = rfidInfo;
  82. }
  83. }
  84. else
  85. {
  86. lg.WriteLog(LogType.serverLog, $"获取RFID信息失败:{rfids.Message}");
  87. }
  88. }
  89. }
  90. else
  91. {
  92. if (CacleCls.rifdInfo == null || CacleCls.rifdInfo.Count == 0)
  93. {
  94. //读取本地rfid数据文件
  95. try
  96. {
  97. if (File.Exists(dbFile))
  98. {
  99. Dictionary<string, string> rfidInfo = new Dictionary<string, string>();
  100. string[] strs = File.ReadAllLines(dbFile);
  101. foreach (string str in strs)
  102. {
  103. try
  104. {
  105. string[] strInfo = str.Split(',');
  106. if (strInfo.Length == 2)
  107. {
  108. rfidInfo.Add(strInfo[0], strInfo[1]);
  109. }
  110. }
  111. catch { }
  112. }
  113. CacleCls.rifdInfo = rfidInfo;
  114. }
  115. }
  116. catch (Exception ex)
  117. {
  118. lg.WriteLog(LogType.WriteDbLog, "写入信息失败:" + ex.Message);
  119. }
  120. }
  121. }
  122. Thread.Sleep(1000); //1秒ping一次网络
  123. }
  124. }
  125. }
  126. }
  127. }