RecvScanner.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. using ProjectBase.Data.BaseDAL;
  2. using ProjectBase.Data.Logs;
  3. using SIMDP.BLL;
  4. using System;
  5. using System.Net;
  6. using System.Net.Sockets;
  7. using System.Text;
  8. using System.Timers;
  9. namespace SIMDP.Device
  10. {
  11. public class RecvScanner
  12. {
  13. Socket socketScanner = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
  14. System.Timers.Timer timerScanner = null;
  15. IPEndPoint epServer = null;
  16. string address = "";
  17. bool running = false;
  18. Action<string> receiveAct = null;
  19. public RecvScanner(double interval = 1000)
  20. {
  21. socketScanner.Blocking = true;
  22. timerScanner = new System.Timers.Timer(interval);
  23. timerScanner.AutoReset = false;
  24. timerScanner.Elapsed += ReceiveScanner;
  25. }
  26. /// <summary>
  27. /// 启动扫码枪接收线程
  28. /// </summary>
  29. /// <param name="Ip"></param>
  30. /// <param name="Port"></param>
  31. public void Start(string Ip, int Port, Action<string> action)
  32. {
  33. if (running)
  34. {
  35. LogHelper.log.Error($"接收扫码器({address})正在运行中,无法重复启动({Ip})");
  36. return;
  37. }
  38. address = $"{Ip}:{Port.ToString()}";
  39. LogHelper.log.Info($"接收扫码器({address})启动");
  40. epServer = new IPEndPoint(IPAddress.Parse(Ip), Port);
  41. receiveAct = action;
  42. running = true;
  43. timerScanner.Start();
  44. }
  45. public void Stop()
  46. {
  47. running = false;
  48. }
  49. private void ReceiveScanner(object sender, ElapsedEventArgs e)
  50. {
  51. if (!socketScanner.Connected)
  52. {
  53. try
  54. {
  55. socketScanner.Connect(epServer);
  56. LogHelper.log.Info($"接收扫码器({address})已连接,开始接收数据...");
  57. }
  58. catch
  59. {
  60. }
  61. }
  62. else
  63. {
  64. TryReceive();
  65. }
  66. if (running)
  67. timerScanner.Start();
  68. }
  69. private void TryReceive()
  70. {
  71. string data = "";
  72. try
  73. {
  74. byte[] temp = new byte[1024];
  75. while (socketScanner.Poll(2000, SelectMode.SelectRead))
  76. {
  77. int nRead = socketScanner.Receive(temp);
  78. if (nRead == 0)
  79. {
  80. LogHelper.log.Warn($"接收扫码器({address})通信断开,自动重连...");
  81. socketScanner.Close();
  82. return;
  83. }
  84. data += Encoding.UTF8.GetString(temp, 0, nRead).Trim('\n').Trim('\r');
  85. }
  86. }
  87. catch (Exception ex)
  88. {
  89. socketScanner.Close();
  90. LogHelper.log.Error($"接收扫码器({address})数据发生异常:{ex}");
  91. //Tool.LogAndNotice("生产过程报警", 3, $"接收扫码器({address})数据发生异常:{ex}");
  92. }
  93. if (data.Length > 0) // 收到数据后执行动作
  94. {
  95. receiveAct(data);
  96. }
  97. }
  98. }
  99. }