|  |  |  | using DyeingComputer.UserClass; | 
					
						
							|  |  |  | using Newtonsoft.Json; | 
					
						
							|  |  |  | using Newtonsoft.Json.Linq; | 
					
						
							|  |  |  | using ScottPlot; | 
					
						
							|  |  |  | using ScottPlot.Colormaps; | 
					
						
							|  |  |  | using SkiaSharp; | 
					
						
							|  |  |  | using SunlightCentralizedControlManagement_SCCM_.View; | 
					
						
							|  |  |  | using SunlightCentralizedControlManagement_SCCM_.ViewModel; | 
					
						
							|  |  |  | using System; | 
					
						
							|  |  |  | using System.Collections; | 
					
						
							|  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  | using System.Data; | 
					
						
							|  |  |  | using System.Diagnostics; | 
					
						
							|  |  |  | using System.Linq; | 
					
						
							|  |  |  | using System.Net; | 
					
						
							|  |  |  | using System.Net.Http; | 
					
						
							|  |  |  | using System.Net.Sockets; | 
					
						
							|  |  |  | using System.Reflection.Emit; | 
					
						
							|  |  |  | using System.Runtime.InteropServices; | 
					
						
							|  |  |  | using System.Text; | 
					
						
							|  |  |  | using System.Threading; | 
					
						
							|  |  |  | using System.Threading.Tasks; | 
					
						
							|  |  |  | using System.Windows; | 
					
						
							|  |  |  | using System.Xml.Linq; | 
					
						
							|  |  |  | using TouchSocket.Core; | 
					
						
							|  |  |  | using TouchSocket.Sockets; | 
					
						
							|  |  |  | using static SunlightCentralizedControlManagement_SCCM_.UserClass.SqliteHelper; | 
					
						
							|  |  |  | using static System.Windows.Forms.AxHost; | 
					
						
							|  |  |  | using static System.Windows.Forms.VisualStyles.VisualStyleElement; | 
					
						
							|  |  |  | using static System.Windows.Forms.VisualStyles.VisualStyleElement.TaskbarClock; | 
					
						
							|  |  |  | using TcpClient = TouchSocket.Sockets.TcpClient; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace SunlightCentralizedControlManagement_SCCM_.UserClass | 
					
						
							|  |  |  | {/// <summary>
 | 
					
						
							|  |  |  |  /// 异步TCP客户端
 | 
					
						
							|  |  |  |  /// </summary>
 | 
					
						
							|  |  |  |     public class AsyncTcpClient | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         private static SQLiteHelper SQLiteHelpers = null;  //定义数据库
 | 
					
						
							|  |  |  |         private static readonly string DBAddress = Environment.CurrentDirectory + "\\DataBase\\SCCM.db";  //数据库路径
 | 
					
						
							|  |  |  |         private static readonly string ChartAdress = Environment.CurrentDirectory + "\\DataBase\\Chart.db";  //数据库路径
 | 
					
						
							|  |  |  |         public static async Task TcpClient(TcpClient tcpClient, string ip, string port) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             //TcpClient tcpClient = new TcpClient();       
 | 
					
						
							|  |  |  |             tcpClient.Connecting = (client, e) => { return EasyTask.CompletedTask; };//即将连接到服务器,此时已经创建socket,但是还未建立tcp
 | 
					
						
							|  |  |  |             tcpClient.Connected = (client, e) => | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 try | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     DataRow drEmployee = MainWindowViewModel.Machines.Select("IP='" + client.IP + "'").First(); | 
					
						
							|  |  |  |                     drEmployee.BeginEdit(); | 
					
						
							|  |  |  |                     drEmployee["State"] = "801"; | 
					
						
							|  |  |  |                     drEmployee.EndEdit(); | 
					
						
							|  |  |  |                     drEmployee.AcceptChanges(); | 
					
						
							|  |  |  |                     LogGing.LogGingDATA("[IP='" + client.IP + "' AND port='" + client.Port + "']=Link_OK"); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 catch (Exception ex) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     LogGing.ERRDATA(ex); MainWindowViewModel.ERR_c++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return EasyTask.CompletedTask; | 
					
						
							|  |  |  |             };//成功连接到服务器
 | 
					
						
							|  |  |  |             tcpClient.Closing = (client, e) => | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 try | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     DataRow drEmployee = MainWindowViewModel.Machines.Select("IP='" + client.IP + "'").First(); | 
					
						
							|  |  |  |                     drEmployee.BeginEdit(); | 
					
						
							|  |  |  |                     drEmployee["State"] = "800"; | 
					
						
							|  |  |  |                     drEmployee["WorkOrder"] = "------"; | 
					
						
							|  |  |  |                     drEmployee["Dyelot"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Temperature"] = "---.-"; | 
					
						
							|  |  |  |                     drEmployee["WaterLevel"] = "----"; | 
					
						
							|  |  |  |                     drEmployee["Process"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Step"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Message"] = ""; | 
					
						
							|  |  |  |                     drEmployee["SYSKEY"] = ""; | 
					
						
							|  |  |  |                     drEmployee["WORK_RUN"] = "-1"; | 
					
						
							|  |  |  |                     drEmployee.EndEdit(); | 
					
						
							|  |  |  |                     drEmployee.AcceptChanges(); | 
					
						
							|  |  |  |                     LogGing.LogGingDATA("[IP='" + client.IP + "' AND port='" + client.Port + "']=Link_STOP"); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 catch (Exception ex) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     LogGing.ERRDATA(ex); MainWindowViewModel.ERR_c++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 return EasyTask.CompletedTask; | 
					
						
							|  |  |  |             };//即将从服务器断开连接。此处仅主动断开才有效。
 | 
					
						
							|  |  |  |             tcpClient.Closed = (client, e) => | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 try | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     DataRow drEmployee = MainWindowViewModel.Machines.Select("IP='" + client.IP + "'").First(); | 
					
						
							|  |  |  |                     drEmployee.BeginEdit(); | 
					
						
							|  |  |  |                     drEmployee["State"] = "800"; | 
					
						
							|  |  |  |                     drEmployee["WorkOrder"] = "------"; | 
					
						
							|  |  |  |                     drEmployee["Dyelot"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Temperature"] = "---.-"; | 
					
						
							|  |  |  |                     drEmployee["WaterLevel"] = "----"; | 
					
						
							|  |  |  |                     drEmployee["Process"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Step"] = ""; | 
					
						
							|  |  |  |                     drEmployee["Message"] = ""; | 
					
						
							|  |  |  |                     drEmployee["SYSKEY"] = ""; | 
					
						
							|  |  |  |                     drEmployee["WORK_RUN"] = "-1"; | 
					
						
							|  |  |  |                     drEmployee.EndEdit(); | 
					
						
							|  |  |  |                     drEmployee.AcceptChanges(); | 
					
						
							|  |  |  |                     LogGing.LogGingDATA("[IP='" + client.IP + "' AND port='" + client.Port + "']=Link_INTERRUPT"); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 catch (Exception ex) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     LogGing.ERRDATA(ex); MainWindowViewModel.ERR_c++; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 return EasyTask.CompletedTask; | 
					
						
							|  |  |  |             };//从服务器断开连接,当连接不成功时不会触发。           
 | 
					
						
							|  |  |  |             tcpClient.Received = (client, e) => | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 //从服务器收到信息。但是一般byteBlock和requestInfo会根据适配器呈现不同的值。
 | 
					
						
							|  |  |  |                 string SYSAPI = e.ByteBlock.Span.ToString(Encoding.ASCII).Substring(0, 5); | 
					
						
							|  |  |  |                 string DAT = e.ByteBlock.Span.ToString(Encoding.UTF8); | 
					
						
							|  |  |  |                 if (SYSAPI == "SC800") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         Dictionary<string, object> Chart_new = new Dictionary<string, object>();//缓存函数                  
 | 
					
						
							|  |  |  |                         Chart_new = JsonConvert.DeserializeObject<Dictionary<string, object>>(DAT);//反序列化
 | 
					
						
							|  |  |  |                         DataRow drEmployee = MainWindowViewModel.Machines.Select("IP='" + client.IP + "'").First(); | 
					
						
							|  |  |  |                         drEmployee.BeginEdit(); | 
					
						
							|  |  |  |                         drEmployee["SYSKEY"] = Chart_new.GetValue("SYSKEY").ToString(); | 
					
						
							|  |  |  |                       //  drEmployee["NAME"] = Chart_new.GetValue("MACHINE").ToString();
 | 
					
						
							|  |  |  |                         drEmployee["Groups"] = Chart_new.GetValue("GROUP").ToString(); | 
					
						
							|  |  |  |                         drEmployee["State"] = "802"; | 
					
						
							|  |  |  |                         drEmployee.EndEdit(); | 
					
						
							|  |  |  |                         drEmployee.AcceptChanges(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         LogGing.ERRDATA(ex); MainWindowViewModel.ERR_c++; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC810") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         SQLiteHelpers = new SQLiteHelper(DBAddress); //数据库连接路径
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Open();  //打开数据库                                                    
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Update("WorkOrder", new Dictionary<string, object> { { "State", 111 } }, | 
					
						
							|  |  |  |                             "WorkOrder ='" + DAT + "'", null); | 
					
						
							|  |  |  |                         SQLiteHelpers.Close(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC811") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         SQLiteHelpers = new SQLiteHelper(DBAddress); //数据库连接路径
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Open();  //打开数据库                                                    
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Update("WorkOrder", new Dictionary<string, object> { { "State", 101 } }, | 
					
						
							|  |  |  |                             "WorkOrder ='" + DAT + "'", null); | 
					
						
							|  |  |  |                         SQLiteHelpers.Close(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC830") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         Dictionary<string, object> _new = new Dictionary<string, object>();//缓存函数                  
 | 
					
						
							|  |  |  |                         _new = JsonConvert.DeserializeObject<Dictionary<string, object>>(DAT);//反序列化
 | 
					
						
							|  |  |  |                         DataRow drEmployee = MainWindowViewModel.Machines.Select("IP='" + client.IP + "'").First(); | 
					
						
							|  |  |  |                         drEmployee.BeginEdit(); | 
					
						
							|  |  |  |                         drEmployee["ERR"] = _new.GetValue("ERR"); | 
					
						
							|  |  |  |                         drEmployee["LOCK"] = _new.GetValue("LOCK"); | 
					
						
							|  |  |  |                         drEmployee["Message"] = _new.GetValue("Status"); | 
					
						
							|  |  |  |                         drEmployee["WorkOrder"] = _new.GetValue("WorkNumder"); | 
					
						
							|  |  |  |                         drEmployee["Temperature"] = _new.GetValue("MTT"); | 
					
						
							|  |  |  |                         drEmployee["WaterLevel"] = _new.GetValue("MTL"); | 
					
						
							|  |  |  |                         drEmployee["Process"] = _new.GetValue("Process"); | 
					
						
							|  |  |  |                         drEmployee["Step"] = _new.GetValue("Step"); | 
					
						
							|  |  |  |                         if (_new.GetValue("UserButton").ToString()!="900") drEmployee["UserButton"] = _new.GetValue("UserButton"); | 
					
						
							|  |  |  |                         drEmployee["UserInfo"] = _new.GetValue("UserInfo"); | 
					
						
							|  |  |  |                         drEmployee["WORK_RUN"] = _new.GetValue("WORK_RUN"); | 
					
						
							|  |  |  |                         drEmployee["RUN_STEPID"] = _new.GetValue("RUN_STEPID"); | 
					
						
							|  |  |  |                         drEmployee["CALL"] = _new.GetValue("CALL"); | 
					
						
							|  |  |  |                         drEmployee.EndEdit(); | 
					
						
							|  |  |  |                         drEmployee.AcceptChanges(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                         if (_new.GetValue("Status").ToString() != "----------") | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             Dictionary<string, object> Chart_new = new Dictionary<string, object>();//缓存函数                                               
 | 
					
						
							|  |  |  |                             Chart_new.Add("WorkOrder", _new.GetValue("WorkNumder")); | 
					
						
							|  |  |  |                             Chart_new.Add("Machine", _new.GetValue("Machine")); | 
					
						
							|  |  |  |                             Chart_new.Add("Time", _new.GetValue("Time")); | 
					
						
							|  |  |  |                             Chart_new.Add("MST", _new.GetValue("MST")); | 
					
						
							|  |  |  |                             Chart_new.Add("MTT", _new.GetValue("MTT")); | 
					
						
							|  |  |  |                             Chart_new.Add("MTL", _new.GetValue("MTL")); | 
					
						
							|  |  |  |                             Chart_new.Add("MTH", _new.GetValue("MTH")); | 
					
						
							|  |  |  |                             Chart_new.Add("MUT", _new.GetValue("MUT")); | 
					
						
							|  |  |  |                             Chart_new.Add("STTA", _new.GetValue("STTA")); | 
					
						
							|  |  |  |                             Chart_new.Add("STLA", _new.GetValue("STLA")); | 
					
						
							|  |  |  |                             Chart_new.Add("STTB", _new.GetValue("STTB")); | 
					
						
							|  |  |  |                             Chart_new.Add("STLB", _new.GetValue("STLB")); | 
					
						
							|  |  |  |                             Chart_new.Add("STTC", _new.GetValue("STTC")); | 
					
						
							|  |  |  |                             Chart_new.Add("STLC", _new.GetValue("STLC")); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                             SQLiteHelpers = new SQLiteHelper(ChartAdress); //数据库连接路径
 | 
					
						
							|  |  |  |                             SQLiteHelpers.Open();  //打开数据库
 | 
					
						
							|  |  |  |                             SQLiteHelpers.InsertData("Chart", Chart_new);// 执行插入                                                     
 | 
					
						
							|  |  |  |                             SQLiteHelpers.Close(); | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//当前信息
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC831") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_TP = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC832") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         MainWindowViewModel.MachineLOG = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//当前细节信息
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC833") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1);                     | 
					
						
							|  |  |  |                         MonitorView.Product_DAT = JsonConvert.DeserializeObject<DataTable>(DAT).Copy();//反序列化
 | 
					
						
							|  |  |  |                        MonitorView.Product_bool=true; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//当前领料单信息
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC851") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_d = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//数字开关表
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC852") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_a = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//寄存器表
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC853") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_m = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//缓存表
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC854") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_ParameterSet = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//程序设置表
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC855") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         MainWindowViewModel.dt_SysSet = JsonConvert.DeserializeObject<DataTable>(DAT);//反序列化
 | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//系统设置表
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC910") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         SQLiteHelpers.Open();  //打开数据库                                                    
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Update("WorkOrder", new Dictionary<string, object> { { "State", 109 } }, | 
					
						
							|  |  |  |                             "WorkOrder ='" + DAT + "'", null); | 
					
						
							|  |  |  |                         SQLiteHelpers.Close(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//发布失败
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC911") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     try | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                         SQLiteHelpers.Open();  //打开数据库                                                    
 | 
					
						
							|  |  |  |                         SQLiteHelpers.Update("WorkOrder", new Dictionary<string, object> { { "State", 119 } }, | 
					
						
							|  |  |  |                             "WorkOrder ='" + DAT + "'", null); | 
					
						
							|  |  |  |                         SQLiteHelpers.Close(); | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     catch (Exception ex) { LogGing.LogGingDATA("[ERR='" + ex + "']=Exception"); MainWindowViewModel.ERR_c++; } | 
					
						
							|  |  |  |                 }//细节错误
 | 
					
						
							|  |  |  |                 else if (SYSAPI == "SC980") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     DAT = DAT.Substring(DAT.IndexOf("]") + 1); | 
					
						
							|  |  |  |                     MessageBox.Show(DAT, "SCCM", MessageBoxButton.OK, MessageBoxImage.Question); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                    | 
					
						
							|  |  |  |                 return EasyTask.CompletedTask; | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             //载入配置
 | 
					
						
							|  |  |  |             await tcpClient.SetupAsync(new TouchSocketConfig() | 
					
						
							|  |  |  |                 .SetMaxBufferSize(1024*1024) | 
					
						
							|  |  |  |                 .SetMinBufferSize(1024*64) | 
					
						
							|  |  |  |                   .SetRemoteIPHost(ip + ":" + port) | 
					
						
							|  |  |  |                   .ConfigurePlugins(a => | 
					
						
							|  |  |  |                   { | 
					
						
							|  |  |  |                       a.UseCheckClear() | 
					
						
							|  |  |  |                       .SetCheckClearType(CheckClearType.All) | 
					
						
							|  |  |  |                       .SetTick(TimeSpan.FromSeconds(60))                       | 
					
						
							|  |  |  |                       .SetOnClose((c, t) => | 
					
						
							|  |  |  |                       { | 
					
						
							|  |  |  |                           c.TryShutdown(); | 
					
						
							|  |  |  |                       }); | 
					
						
							|  |  |  |                       a.UseTcpReconnection();//触发型重连
 | 
					
						
							|  |  |  |                   })              | 
					
						
							|  |  |  |                   .ConfigureContainer(a => | 
					
						
							|  |  |  |                   { | 
					
						
							|  |  |  |                       // a.AddConsoleLogger();//添加一个日志注入
 | 
					
						
							|  |  |  |                   })); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // Result result = await 
 | 
					
						
							|  |  |  |             _ = tcpClient.TryConnectAsync(); | 
					
						
							|  |  |  |             //  return result.IsSuccess;
 | 
					
						
							|  |  |  |             /*   try | 
					
						
							|  |  |  |                { | 
					
						
							|  |  |  |                    await tcpClient.ConnectAsync();//调用连接,当连接不成功时,会抛出异常。
 | 
					
						
							|  |  |  |                    return true; | 
					
						
							|  |  |  |                } | 
					
						
							|  |  |  |                catch  | 
					
						
							|  |  |  |                { | 
					
						
							|  |  |  |                    return false; | 
					
						
							|  |  |  |                }*/ | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |