RobotBackgroundService.cs
5.16 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
using AutomaticGrooveCalculationTool.Common.Utils;
using AutomaticGrooveCalculationTool.Model;
using System.Net;
using System.Net.Sockets;
using System.Text;
using System.Xml.Serialization;
namespace AutomaticGrooveCalculationTool.Services
{
public class RobotBackgroundService : BackgroundService
{
private readonly SystemLog _logger = SystemLog.Instance;
private readonly SiemensPLCService _siemensPLC;
private readonly GrooveService _grooveService;
private readonly TcpListener _tcpServer;
public RobotBackgroundService(SiemensPLCService siemensPLC, GrooveService grooveService)
{
_tcpServer = new TcpListener(IPAddress.Any, 59152);
_tcpServer.Start();
_siemensPLC = siemensPLC;
_grooveService = grooveService;
}
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
_tcpServer.BeginAcceptTcpClient(DoAcceptTcpClient, _tcpServer);
while (!stoppingToken.IsCancellationRequested)
{
foreach (var item in _siemensPLC.Equipments.GroupBy(x => x.IP))
{
var plcIP = item.Key;
try
{
var plc = _siemensPLC.Plcs.First(x => x.IP == plcIP);
if (!plc.IsConnected)
{
await plc.OpenAsync(stoppingToken);
}
if (!plc.IsConnected)
{
_logger.LogWarning($"PLC[{plcIP}]连接失败");
continue;
}
_siemensPLC.Read(item.SelectMany(x => x.EquipmentProps));
}
catch (Exception ex)
{
_logger.LogError($"设备{item.Key}执行线程出现异常,{ex.Message}");
}
}
await Task.Delay(500, stoppingToken);
}
}
private void DoAcceptTcpClient(IAsyncResult result)
{
var server = (TcpListener)result.AsyncState!;
var tcpClient = server.EndAcceptTcpClient(result);
_logger.LogInfo($"[客户端[{tcpClient.Client.RemoteEndPoint}]已成功建立连接");
Receive(tcpClient);
server.BeginAcceptTcpClient(DoAcceptTcpClient, server);
}
private void Receive(TcpClient tcpClient)
{
Task.Run(() =>
{
var remoteEndPoint = tcpClient.Client.RemoteEndPoint;
while (tcpClient.Connected)
{
try
{
var buffer = new byte[8192];
var stream = tcpClient.GetStream();
//接收客户端数据
stream.Read(buffer, 0, buffer.Length);
var bufferString = Encoding.Default.GetString(buffer).TrimEnd('\0');
_logger.LogInfo($"接收到客户端[{remoteEndPoint}]报文:{bufferString}");
const string kukaAckFlag1 = "<Robot>";
const string kukaAckFlag2 = "</Robot>";
if (bufferString.StartsWith(kukaAckFlag1, StringComparison.OrdinalIgnoreCase) && bufferString.EndsWith(kukaAckFlag2))
{
var inputXmlSerializer = new XmlSerializer(typeof(InputParameter));
var outputXmlSerializer = new XmlSerializer(typeof(OutputParameter));
using var ms = new MemoryStream();
var writer = new StreamWriter(ms);
writer.Write(bufferString.Trim());
writer.Flush();
ms.Position = 0;
var reader = new StreamReader(ms);
try
{
var request = (InputParameter)inputXmlSerializer.Deserialize(reader)!;
var (outputParameter, _) = _grooveService.GetExcelData(request);
using var sw = new StringWriter();
outputXmlSerializer.Serialize(sw, outputParameter);
var response = sw.ToString();
stream.Write(Encoding.Default.GetBytes(response));
_logger.LogSuccess($"响应客户端[{remoteEndPoint}]请求成功,报文:{response}");
}
catch (Exception ex)
{
_logger.LogError($"响应客户端[{remoteEndPoint}]请求失败:{ex.Message}");
}
}
}
catch (Exception ex)
{
_logger.LogError($"客户端[{remoteEndPoint}]:{ex.InnerException?.Message ?? ex.Message}");
}
}
});
}
}
}