IOServer.Partial.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. namespace MSHO.Collection.Service.IO
  7. {
  8. partial class IOServer
  9. {
  10. private object m_lock_client = new object();
  11. private Dictionary<string, Task> m_ClientTask = new Dictionary<string, Task>();
  12. public void StartClientTask(System.Net.Sockets.Socket client) {
  13. var task = new System.Threading.Tasks.Task(ProcessClientMsg, client);
  14. task.Start();
  15. }
  16. private void ProcessClientMsg(object state) {
  17. var client = state as System.Net.Sockets.Socket;
  18. try
  19. {
  20. do
  21. {
  22. var msg = ReceiveMsg(client);
  23. if (msg == null)
  24. {
  25. #if DEBUG
  26. Console.WriteLine("msg == null");
  27. #endif
  28. break;
  29. }
  30. else if (msg.BadMsg)
  31. {
  32. SendMsg(client, new Message(new Msg()
  33. {
  34. Content = "错误的请求消息"
  35. }));
  36. } else if(msg.Length > (long)0) {
  37. var mm = Msg.ParseMsg(msg);
  38. if (mm != null)
  39. {
  40. switch (mm.MessageType)
  41. {
  42. case MessageTypeEnum.Connect:
  43. ProcessConnectMsg(client, mm);
  44. break;
  45. case MessageTypeEnum.Heart:
  46. ProcessHeartMsg(client, mm);
  47. break;
  48. case MessageTypeEnum.ReportData:
  49. ProcessReportDataMsg(client, mm);
  50. break;
  51. case MessageTypeEnum.ErrorData:
  52. Process_Exception(client, mm);
  53. break;
  54. case MessageTypeEnum.UploadFile:
  55. Process_UploadFile(client, mm);
  56. break;
  57. case MessageTypeEnum.GetUploadFile:
  58. Process_GetUploadFile(client, mm);
  59. break;
  60. }
  61. }
  62. else
  63. {
  64. SendMsg(client, new Message(new Msg()
  65. {
  66. Content = "错误的请求消息"
  67. }));
  68. }
  69. }
  70. } while (m_Running);
  71. }
  72. catch (Exception ex)
  73. {
  74. MSHO.Collection.DataAccess.MSHOService.Instance.SaveSystemLog("MSHO.Collection.Service", "ProcessClientMsg", ex);
  75. }
  76. finally
  77. {
  78. if (client != null)
  79. {
  80. try
  81. {
  82. #if DEBUG
  83. Console.WriteLine(".............................................断开客户端连接");
  84. #endif
  85. client.Close();
  86. }
  87. catch { }
  88. }
  89. }
  90. }
  91. private void ProcessReportDataMsg(System.Net.Sockets.Socket client, Msg data)
  92. {
  93. #if DEBUG
  94. Console.WriteLine("收到数据,开始处理");
  95. var watch = new System.Diagnostics.Stopwatch();
  96. watch.Start();
  97. #endif
  98. var msg = new DataReportRespMsg();
  99. msg.ClientCode = data.ClientCode;
  100. var data_report = data as DataReportMsg;
  101. if (data_report != null) {
  102. switch (data_report.DataType) {
  103. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.Bus_Weighting:
  104. Process_Bus_Weighting(msg, data_report);
  105. break;
  106. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.Access_Weighting:
  107. Process_Access_Weighting(msg, data_report);
  108. break;
  109. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.Kdtc_Weighting:
  110. Process_Kdtc_Weighting(msg, data_report);
  111. break;
  112. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.SQL2000_DiBangData_Weighting:
  113. Process_SQL2000_DiBangData_Weighting(msg, data_report);
  114. break;
  115. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.SQL2000_oreManageDBCli_Weighting:
  116. Process_SQL2000_oreManageDBCli_Weighting(msg, data_report);
  117. break;
  118. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.SQL2000_oreManageDBCli_2_Weighting:
  119. Process_SQL2000_oreManageDBCli_2_Weighting(msg, data_report);
  120. break;
  121. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.SQL2000_oreManageDBCli_3_Weighting:
  122. Process_SQL2000_oreManageDBCli_3_Weighting(msg, data_report);
  123. break;
  124. case MSHO.Collection.DataAccess.ClientModels.ClientDataType.LowSpeedNew_Weighting:
  125. Process_LowSpeedNew_Weighting(msg, data_report);
  126. break;
  127. }
  128. }
  129. SendMsg(client, new Message(msg));
  130. #if DEBUG
  131. watch.Stop();
  132. Console.WriteLine("处理完成SaveWeighting({0}): {1}", msg.ClientCode, watch.Elapsed);
  133. #endif
  134. }
  135. private void ProcessConnectMsg(System.Net.Sockets.Socket client, Msg connect) {
  136. #if DEBUG
  137. Console.WriteLine("{0}获取配置", connect.ClientCode);
  138. #endif
  139. var config = MSHO.Collection.DataAccess.MSHOService.Instance.GetCollectConfigByCode(connect.ClientCode);
  140. if (config != null) {
  141. var msg = new ConnectRespMsg();
  142. msg.ClientCode = connect.ClientCode;
  143. var serverConfig = config.ToServerConfig();
  144. if (serverConfig != null) {
  145. serverConfig.LastSourceID = config.LastSourceID;
  146. serverConfig.LastSourceTime = config.LastSourceTime;
  147. msg.Content = serverConfig.ToJson();
  148. SendMsg(client, new Message(msg));
  149. return;
  150. }
  151. }
  152. SendMsg(client, new Message(new Msg()
  153. {
  154. Content = "未知的采集编号"
  155. }));
  156. }
  157. private void ProcessHeartMsg(System.Net.Sockets.Socket client, Msg heart)
  158. {
  159. var msg = new HeartRespMsg();
  160. msg.ClientCode = heart.ClientCode;
  161. msg.Time = DateTime.Now;
  162. MSHO.Collection.DataAccess.MSHOService.Instance.UpdateDeviceStatus(heart.ClientCode);
  163. #if DEBUG
  164. Console.WriteLine("心跳消息:{0}", heart.ClientCode);
  165. #endif
  166. SendMsg(client, new Message(msg));
  167. }
  168. private void Process_UploadFile(System.Net.Sockets.Socket client, Msg data) {
  169. #if DEBUG
  170. Console.WriteLine("开始处理文件...");
  171. #endif
  172. var msg = new UploadFileMsgRespMsg();
  173. msg.ClientCode = data.ClientCode;
  174. var uploadFileMsg = data as UploadFileMsg;
  175. if (uploadFileMsg != null) {
  176. if (uploadFileMsg.WeightingID > 0)
  177. {
  178. if (!string.IsNullOrEmpty(uploadFileMsg.FileStreamBase64))
  179. {
  180. msg.Result = MSHO.Collection.DataAccess.MSHOService.Instance.SaveWeightingFile(uploadFileMsg.ID, uploadFileMsg.WeightingID, uploadFileMsg.FileStreamBase64, uploadFileMsg.BufferLength);
  181. }
  182. else
  183. {
  184. msg.Result = true;
  185. }
  186. }
  187. }
  188. SendMsg(client, new Message(msg));
  189. #if DEBUG
  190. Console.WriteLine("...............处理文件完成");
  191. #endif
  192. }
  193. private void Process_GetUploadFile(System.Net.Sockets.Socket client, Msg data)
  194. {
  195. var msg = new GetUploadFileMsgRespMsg();
  196. msg.ClientCode = data.ClientCode;
  197. MSHO.Collection.DataAccess.Models.CollectConfig clientConfig = null;
  198. if (m_CollectConfigs.ContainsKey(msg.ClientCode))
  199. {
  200. clientConfig = m_CollectConfigs[msg.ClientCode];
  201. }
  202. if (clientConfig == null)
  203. {
  204. clientConfig = MSHO.Collection.DataAccess.MSHOService.Instance.GetCollectConfigByCode(msg.ClientCode);
  205. }
  206. msg.WeightingFiles = MSHO.Collection.DataAccess.MSHOService.Instance.GetWeightingFileByDeviceID(clientConfig.DeviceID).Take(10).ToList();
  207. SendMsg(client, new Message(msg));
  208. }
  209. private Message ReceiveMsg(System.Net.Sockets.Socket client)
  210. {
  211. try
  212. {
  213. var msg = new Message();
  214. var buffer = new byte[sizeof(long)];
  215. if (client.Connected)
  216. {
  217. var len = client.Receive(buffer, 0, buffer.Length, System.Net.Sockets.SocketFlags.None);
  218. if (len > 0 && len == sizeof(long))
  219. {
  220. var length = Helper.BytesToLong(buffer);
  221. #if DEBUG
  222. if (length > 0)
  223. {
  224. Console.WriteLine("开始接收消息({0})", length);
  225. }
  226. #endif
  227. if (length > 0)
  228. {
  229. var stream = new System.IO.MemoryStream();
  230. while (stream.Length < length)
  231. {
  232. buffer = new byte[length];
  233. len = client.Receive(buffer, 0, buffer.Length, System.Net.Sockets.SocketFlags.None);
  234. if (len > 0)
  235. {
  236. stream.Write(buffer, 0, len);
  237. }
  238. else
  239. {
  240. msg.BadMsg = true;
  241. break;
  242. }
  243. }
  244. msg.Write(stream.ToArray());
  245. }
  246. #if DEBUG
  247. if (msg.BadMsg == false && msg.Length > 0)
  248. {
  249. Console.WriteLine("................消息接收完成({0})", msg.Length);
  250. }
  251. #endif
  252. }
  253. else {
  254. msg.BadMsg = true;
  255. }
  256. }
  257. return msg;
  258. }
  259. catch (Exception ex)
  260. {
  261. Console.WriteLine(ex.Message);
  262. }
  263. return null;
  264. }
  265. private void SendMsg(System.Net.Sockets.Socket client, Message msg)
  266. {
  267. if (m_Running && client != null)
  268. {
  269. if (client.Connected)
  270. {
  271. var buffer = msg.ToBuffer();
  272. client.Send(buffer, 0, buffer.Length, System.Net.Sockets.SocketFlags.None);
  273. }
  274. }
  275. }
  276. }
  277. }