Form_Main.cs 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897
  1. using HslCommunication.Enthernet;
  2. using IMCS.Device;
  3. using IMCS_CCS.Utils.DeviceProtocol;
  4. using Newtonsoft.Json;
  5. using Opc.Ua;
  6. using Opc.Ua.Client;
  7. using SinumerikOpcUaAPI;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.ComponentModel;
  11. using System.Data;
  12. using System.Diagnostics;
  13. using System.Drawing;
  14. using System.IO;
  15. using System.Linq;
  16. using System.Net;
  17. using System.Runtime.Serialization.Formatters.Binary;
  18. using System.Runtime.Serialization;
  19. using System.Text;
  20. using System.Threading;
  21. using System.Threading.Tasks;
  22. using System.Windows.Forms;
  23. using YG;
  24. using YG.Device;
  25. using static SinumerikOpcUaAPI.Server;
  26. using System.Collections;
  27. using System.Runtime.Remoting.Messaging;
  28. using System.Reflection.Emit;
  29. using System.Runtime.Remoting.Channels;
  30. using System.Net.NetworkInformation;
  31. using static System.Windows.Forms.VisualStyles.VisualStyleElement.Tab;
  32. namespace IMCS
  33. {
  34. public partial class Form_Main : Form
  35. {
  36. //public string UPLOAD_NC_PATH = "Sinumerik/FileSystem/Work Pieces/";
  37. public string UPLOAD_NC_PATH = "Sinumerik/FileSystem/NCExtend/wks.dir/nc_program/";
  38. //public string UPLOAD_NC_PATH = "Sinumerik/FileSystem/Work Pieces/WORK_NC/";
  39. public string CHANNEL_NO = "1";
  40. public string TEMP_NC_NAME = "7999.MPF";
  41. private uint currentToolArea = 1;
  42. private ushort mNAMESPACE_INDEX = 2;
  43. // 作为长连接进行bean的存储, key使用ip,
  44. Dictionary<string, Server> opcServerMap = new Dictionary<string, Server>();
  45. public Dictionary<string, Server> deviceList { get; set; } = new Dictionary<string, Server>();
  46. public Form_Main()
  47. {
  48. InitializeComponent();
  49. }
  50. private void Form1_Load(object sender, EventArgs e)
  51. {
  52. HttpListener httpListenner;
  53. httpListenner = new HttpListener();
  54. httpListenner.AuthenticationSchemes = AuthenticationSchemes.Anonymous;
  55. httpListenner.Prefixes.Add("http://127.0.0.1:8010/opcua/");
  56. httpListenner.Start();
  57. label1.Text = "HttpServer已开启:http://127.0.0.1:8010/opcua/";
  58. new Thread(new ThreadStart(delegate
  59. {
  60. try
  61. {
  62. loop(httpListenner);
  63. }
  64. catch (Exception ex)
  65. {
  66. string ss = ex.ToString();
  67. httpListenner.Stop();
  68. /* Application.ExitThread();
  69. Application.Exit();
  70. Application.Restart();
  71. Process.GetCurrentProcess().Kill();*/
  72. }
  73. })).Start();
  74. }
  75. private void loop(HttpListener httpListenner)
  76. {
  77. while (true)
  78. {
  79. HttpListenerContext context = httpListenner.GetContext();
  80. context.Response.AppendHeader("Access-Control-Allow-Origin", "*");
  81. HttpListenerRequest request = context.Request;
  82. HttpListenerResponse response = context.Response;
  83. Servlet servlet = new MyServlet();
  84. servlet.onCreate();
  85. if (request.HttpMethod == "POST")
  86. {
  87. if (!request.Url.ToString().Contains("favicon"))
  88. {
  89. RequestBody opcBody = null;
  90. ResponseBody responseBody = new ResponseBody();
  91. Server opcServer = null;
  92. try
  93. {
  94. Stream stream = context.Request.InputStream;
  95. StreamReader reader = new StreamReader(stream, Encoding.UTF8);
  96. string body = reader.ReadToEnd();
  97. YG.Log.Instance.WriteLogAdd(">>>===收到POST数据 : >>>>===" + body);
  98. opcBody = JsonConvert.DeserializeObject<RequestBody>(body);
  99. AddList(DateTime.Now.ToString(), "POST", opcBody.ServerUrl + opcBody.Type, "OK");
  100. /*if (deviceList == null || (deviceList.Where(m => m.Key.Equals(opcBody.ServerUrl)).Count() == 0))
  101. {
  102. opcServer = DeviceOPCUat.OpcUa_Connection1(opcBody.ServerUrl, opcBody.UserName, opcBody.Password);
  103. if (opcServer.Session != null)
  104. {
  105. deviceList.Add(opcBody.ServerUrl, opcServer);
  106. }
  107. }
  108. else
  109. {
  110. opcServer = deviceList.Where(m => m.Key.Equals(opcBody.ServerUrl)).FirstOrDefault().Value;
  111. }*/
  112. /*if (opcServer == null || !opcServer.Session.Connected)
  113. {
  114. opcServer = DeviceOPCUat.OpcUa_Connection1(opcBody.ServerUrl, opcBody.UserName, opcBody.Password);
  115. }*/
  116. // 从map中取出opcServer 判断是否存在,以及是否可用
  117. opcServerMap.TryGetValue(opcBody.ServerUrl, out opcServer);
  118. // 如果key不存在,或者存在单连接不上,则需要重新创建连接
  119. if (!opcServerMap.ContainsKey(opcBody.ServerUrl) || !opcServer.Session.Connected)
  120. {
  121. Ping pingSender = new Ping();
  122. PingReply reply = pingSender.Send(opcBody.Ip);
  123. if (reply.Status == IPStatus.Success)
  124. {
  125. opcServer = DeviceOPCUat.OpcUa_Connection1(opcBody.ServerUrl, opcBody.UserName, opcBody.Password);
  126. }
  127. if (opcServer != null && opcServer.Session != null && opcServer.Session.Connected) {
  128. // 存储Server bean
  129. opcServerMap.Add(opcBody.ServerUrl, opcServer);
  130. }
  131. }
  132. //opcServer = DeviceOPCUat.OpcUa_Connection1(opcBody.ServerUrl, opcBody.UserName, opcBody.Password);
  133. //opcServer.IsOn
  134. //else
  135. //{
  136. // opcServer.Session.Reconnect();
  137. //}
  138. if (opcServer!=null && opcServer.Session!=null && opcServer.Session.Connected)
  139. {
  140. if (opcBody.Type == ActionTypeEnum.Connect.ToString()) //连接状态
  141. {
  142. responseBody.result = true;
  143. }
  144. else if (opcBody.Type == ActionTypeEnum.Collect.ToString()) //采集
  145. {
  146. //ETH_S7Simens s7 = new ETH_S7Simens("192.168.11.164");
  147. //responseBody.runDatasInfo = JsonConvert.SerializeObject(s7.deviceInfo);
  148. // 封装需要采集字段的数据
  149. this.addAddress(opcBody);
  150. List<string> values = opcServer.ReadValues(opcBody.Addresses);
  151. responseBody.values = values;
  152. /*RunDatasInfo runDatasInfo = new RunDatasInfo();
  153. for (int i = 0; i < values.Count; i++)
  154. {
  155. if (i == 0)
  156. {
  157. runDatasInfo.feedRate = values[i];
  158. }
  159. else if (i == 1)
  160. {
  161. runDatasInfo.spindleMagnification = values[i];
  162. }
  163. else if (i == 2)
  164. {
  165. runDatasInfo.spindleSpeed = values[i];
  166. }
  167. else if (i == 3)
  168. {
  169. runDatasInfo.spindleLoad = values[i];
  170. }
  171. else if (i == 4)
  172. {
  173. runDatasInfo.mainPro = values[i];
  174. }
  175. else if (i == 5)
  176. {
  177. runDatasInfo.content = values[i];
  178. }
  179. }
  180. responseBody.runDatasInfo = JsonConvert.SerializeObject(runDatasInfo);*/
  181. /*//报警
  182. SinumerikOpcUaAPI.FilterDefinition m_filter = new SinumerikOpcUaAPI.FilterDefinition();
  183. m_filter.AreaId = new NodeId("Sinumerik", (ushort)2);
  184. m_filter.Severity = EventSeverity.Min;
  185. m_filter.IgnoreSuppressedOrShelved = true;
  186. m_filter.EventTypes = (IList<NodeId>)new NodeId[1]
  187. {
  188. ObjectTypeIds.ConditionType
  189. };
  190. m_filter.SelectClauses = m_filter.ConstructSelectClauses(opcServer.Session, ObjectTypeIds.ConditionType);
  191. for (int index = 0; index < m_filter.SelectClauses.Count<SimpleAttributeOperand>(); ++index)
  192. {
  193. responseBody.errorsInfo += m_filter.SelectClauses[index].ToString() + (object)index + " ";
  194. }*/
  195. }
  196. else if (opcBody.Type == ActionTypeEnum.ToolList.ToString())
  197. {
  198. List<string> nums = this.readVariables(opcServer, new string[1]
  199. {
  200. "/Tool/Catalogue/numTools[u<Area index>]".Replace("<Area index>", this.currentToolArea.ToString())
  201. }
  202. );
  203. int num = int.Parse(nums[0]);
  204. List<ToolsInfo> toolInfoList = new List<ToolsInfo>();
  205. for (int index = 1; index <= num; index++)
  206. {
  207. List<string> stringList = this.readVariables(opcServer, new string[10]
  208. {
  209. "/Tool/Catalogue/toolNo[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  210. "/Tool/Catalogue/toolIdent[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  211. "/Tool/Catalogue/toolInMag[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  212. "/Tool/Catalogue/toolInPlace[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  213. "/Tool/Catalogue/nrDuplo[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  214. "/Tool/Catalogue/numCuttEdges[u<Area index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Row index>", index.ToString()),
  215. "/Tool/Compensation/edgeData[u<Area index>,c<Column index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Column index>",index.ToString()).Replace("<Row index>", "3"),
  216. "/Tool/Compensation/edgeData[u<Area index>,c<Column index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Column index>",index.ToString()).Replace("<Row index>", "6"),
  217. "/Tool/Compensation/edgeData[u<Area index>,c<Column index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Column index>",index.ToString()).Replace("<Row index>", "12"),
  218. "/Tool/Compensation/edgeData[u<Area index>,c<Column index>, <Row index>]".Replace("<Area index>", this.currentToolArea.ToString()).Replace("<Column index>",index.ToString()).Replace("<Row index>", "15")
  219. }
  220. );
  221. ToolsInfo toolInfo = new ToolsInfo(); ;
  222. toolInfo.number = Convert.ToUInt16(stringList[0]) + "";
  223. toolInfo.name = stringList[1];
  224. toolInfo.length = stringList[6];
  225. toolInfo.radius = stringList[7];
  226. toolInfo.wearLength = stringList[8];
  227. toolInfo.wearRadius = stringList[9];
  228. //toolInfo.toolInMag = Convert.ToUInt16(stringList[2]);
  229. //toolInfo.toolInPlace = Convert.ToUInt16(stringList[3]);
  230. //toolInfo.nrDuplo = Convert.ToUInt16(stringList[4]);
  231. //toolInfo.numCuttEdges = Convert.ToUInt16(stringList[5]);
  232. toolInfoList.Add(toolInfo);
  233. }
  234. responseBody.toolsInfo = JsonConvert.SerializeObject(toolInfoList);
  235. }
  236. else if (opcBody.Type == ActionTypeEnum.Read.ToString())
  237. {
  238. responseBody.values = opcServer.ReadValues(opcBody.Addresses);
  239. }
  240. else if (opcBody.Type == ActionTypeEnum.Write.ToString())
  241. {
  242. opcServer.WriteValues(opcBody.Values, opcBody.Addresses);
  243. }
  244. else if (opcBody.Type == ActionTypeEnum.SelectNc.ToString())
  245. {
  246. string sSelectedFileName = Path.GetFileName(opcBody.Path);
  247. string status = opcServer.MethodCallSelectProgram(UPLOAD_NC_PATH + sSelectedFileName, Convert.ToUInt32(CHANNEL_NO)).status;
  248. if (status == "Good")
  249. {
  250. responseBody.msg = "选择成功";
  251. }
  252. else
  253. {
  254. responseBody.msg = "选择失败";
  255. }
  256. }
  257. else if (opcBody.Type == ActionTypeEnum.Upload.ToString())
  258. {
  259. string file = opcBody.Path;
  260. string serverPath = "";
  261. string status = "";
  262. //选择临时文件
  263. status = opcServer.MethodCallSelectProgram(UPLOAD_NC_PATH + TEMP_NC_NAME, Convert.ToUInt32(CHANNEL_NO)).status;
  264. try
  265. {
  266. string extension = Path.GetExtension(file);
  267. if (string.IsNullOrWhiteSpace(extension))
  268. {
  269. responseBody.msg = "文件名不合法";
  270. }
  271. try
  272. {
  273. byte[] data = opcServer.ReadFile(file);
  274. serverPath = UPLOAD_NC_PATH + Path.GetFileName(file);
  275. Server.MethodCallResult methodCallResult = opcServer.MethodCallCopyFileToServer("/Methods/CopyFileToServer", serverPath, data, true);
  276. if (methodCallResult.status.ToUpper().Equals("GOOD"))
  277. {
  278. responseBody.msg = "上传文件成功";
  279. YG.Log.Instance.WriteLogAdd(file + "上传文件成功");
  280. }
  281. else
  282. {
  283. responseBody.msg = "上传文件失败";
  284. YG.Log.Instance.WriteLogAdd(file + "上传文件失败");
  285. }
  286. // }
  287. }
  288. catch (Exception ex)
  289. {
  290. responseBody.msg = "上传文件失败===>" + ex.Message;
  291. YG.Log.Instance.WriteLogAdd($"{ex.Message}");
  292. }
  293. }
  294. catch (Exception ex)
  295. {
  296. responseBody.msg = "上传文件失败===>" + ex.Message;
  297. YG.Log.Instance.WriteLogAdd($"493-->{ex.Message}");
  298. }
  299. //设位主程序
  300. status = opcServer.MethodCallSelectProgram(serverPath, Convert.ToUInt32(CHANNEL_NO)).status;
  301. }
  302. else if (opcBody.Type == ActionTypeEnum.UploadFileList.ToString())
  303. {
  304. //选择临时文件
  305. string status = opcServer.MethodCallSelectProgram(UPLOAD_NC_PATH + TEMP_NC_NAME, Convert.ToUInt32(CHANNEL_NO)).status;
  306. for (int i = 0; i < opcBody.subFileList.Count; i++)
  307. {
  308. string file = opcBody.subFileList[i];
  309. string serverPath = "";
  310. try
  311. {
  312. string extension = Path.GetExtension(file);
  313. if (string.IsNullOrWhiteSpace(extension))
  314. {
  315. responseBody.result = false;
  316. responseBody.msg = file + "==文件名不合法";
  317. break;
  318. }
  319. try
  320. {
  321. byte[] data = opcServer.ReadFile(file);
  322. serverPath = UPLOAD_NC_PATH + Path.GetFileName(file);
  323. Server.MethodCallResult methodCallResult = opcServer.MethodCallCopyFileToServer("/Methods/CopyFileToServer", serverPath, data, true);
  324. if (methodCallResult.status.ToUpper().Equals("GOOD"))
  325. {
  326. responseBody.msg = "上传文件成功";
  327. YG.Log.Instance.WriteLogAdd(file + "上传文件成功");
  328. }
  329. else
  330. {
  331. responseBody.msg = "上传文件失败";
  332. responseBody.result = false;
  333. YG.Log.Instance.WriteLogAdd(file + "上传文件失败");
  334. break;
  335. }
  336. }
  337. catch (Exception ex)
  338. {
  339. responseBody.msg = "上传文件失败===>" + ex.Message;
  340. YG.Log.Instance.WriteLogAdd($"{ex.Message}");
  341. break;
  342. }
  343. }
  344. catch (Exception ex)
  345. {
  346. responseBody.msg = "上传文件失败===>" + ex.Message;
  347. responseBody.result = false;
  348. YG.Log.Instance.WriteLogAdd($"493-->{ex.Message}");
  349. }
  350. }
  351. //设为主程序
  352. status = opcServer.MethodCallSelectProgram(UPLOAD_NC_PATH + opcBody.prgName, Convert.ToUInt32(CHANNEL_NO)).status;
  353. if (status != "Good")
  354. {
  355. responseBody.msg = "选择失败";
  356. responseBody.result = false;
  357. }
  358. }
  359. else if (opcBody.Type == ActionTypeEnum.DownLoad.ToString())
  360. {
  361. string file = opcBody.Path;
  362. string serverPath = "";
  363. try
  364. {
  365. string extension = Path.GetExtension(file);
  366. if (string.IsNullOrWhiteSpace(extension))
  367. {
  368. responseBody.msg = "文件名不合法";
  369. }
  370. try
  371. {
  372. //byte[] data = opcServer.ReadFile(file);
  373. serverPath = UPLOAD_NC_PATH + Path.GetFileName(file);
  374. // Server.MethodCallResult methodCallResult = opcServer.MethodCallCopyFileFromServer("/Methods/CopyFileFromServer", serverPath);
  375. //
  376. byte[] op = opcServer.ReadFile(serverPath);
  377. DiagnosticInfoCollection diagnosticInfos = null;
  378. CallMethodRequestCollection callMethodRequestCollection = new CallMethodRequestCollection();
  379. CallMethodResultCollection results = new CallMethodResultCollection();
  380. CallMethodRequest callMethodRequest = new CallMethodRequest();
  381. callMethodRequest.MethodId = new NodeId("/Methods/CopyFileFromServer", mNAMESPACE_INDEX);
  382. callMethodRequest.ObjectId = new NodeId("/Methods", mNAMESPACE_INDEX);
  383. callMethodRequest.InputArguments.Add(serverPath);
  384. //callMethodRequest.InputArguments.Add(data);
  385. callMethodRequestCollection.Add(callMethodRequest);
  386. RequestHeader requestHeader = new RequestHeader();
  387. ResponseHeader responseHeader = opcServer.Session.Call(null, callMethodRequestCollection, out results, out diagnosticInfos);
  388. Server.MethodCallResult methodCallResult = new MethodCallResult(results);
  389. if (methodCallResult.status.ToUpper().Equals("GOOD"))
  390. {
  391. responseBody.msg = "上传文件成功";
  392. YG.Log.Instance.WriteLogAdd(file + "上传文件成功");
  393. Variant result3 = methodCallResult.results;
  394. byte[] buff;
  395. using (MemoryStream ms = new MemoryStream())
  396. {
  397. IFormatter iFormatter = new BinaryFormatter();
  398. iFormatter.Serialize(ms, result3.Value);
  399. buff = ms.GetBuffer();
  400. }
  401. // 将byte[]写入文件
  402. File.WriteAllBytes(file, buff);
  403. // 读取文件内容到字符串
  404. string fileContent = File.ReadAllText(file);
  405. fileContent = fileContent.Trim();
  406. // 去除字符串中的空格
  407. //string trimmedContent = fileContent.Trim(); // 使用Trim去除字符串首尾的空格
  408. // 或者使用Replace去除所有空格
  409. string trimmedContent = fileContent.Replace(" ", "");
  410. // 将处理过的字符串写回文件
  411. File.WriteAllText(file, trimmedContent);
  412. string aa = result3.ToString();
  413. }
  414. else
  415. {
  416. responseBody.msg = "上传文件失败";
  417. YG.Log.Instance.WriteLogAdd(file + "上传文件失败");
  418. }
  419. // }
  420. }
  421. catch (Exception ex)
  422. {
  423. responseBody.msg = "上传文件失败===>" + ex.Message;
  424. YG.Log.Instance.WriteLogAdd($"{ex.Message}");
  425. }
  426. }
  427. catch (Exception ex)
  428. {
  429. responseBody.msg = "上传文件失败===>" + ex.Message;
  430. YG.Log.Instance.WriteLogAdd($"493-->{ex.Message}");
  431. }
  432. }
  433. else if (opcBody.Type == ActionTypeEnum.Delete.ToString())
  434. {
  435. string file = opcBody.Path;
  436. string serverPath = "";
  437. try
  438. {
  439. string extension = Path.GetExtension(file);
  440. if (string.IsNullOrWhiteSpace(extension))
  441. {
  442. responseBody.msg = "文件名不合法";
  443. }
  444. else
  445. {
  446. try
  447. {
  448. //byte[] data = opcServer.ReadFile(file);
  449. serverPath = UPLOAD_NC_PATH + Path.GetFileName(file);
  450. Server.MethodCallResult methodCallResult = opcServer.MethodCallDeleteFile(serverPath);
  451. if (methodCallResult.status.ToUpper().Equals("GOOD"))
  452. {
  453. responseBody.msg = "删除文件成功";
  454. YG.Log.Instance.WriteLogAdd(file + "删除文件成功");
  455. }
  456. else
  457. {
  458. responseBody.msg = "上传文件失败";
  459. YG.Log.Instance.WriteLogAdd(file + "上传文件失败");
  460. }
  461. // }
  462. }
  463. catch (Exception ex)
  464. {
  465. responseBody.msg = "上传文件失败===>" + ex.Message;
  466. YG.Log.Instance.WriteLogAdd($"{ex.Message}");
  467. }
  468. }
  469. }
  470. catch (Exception ex)
  471. {
  472. responseBody.msg = "上传文件失败===>" + ex.Message;
  473. YG.Log.Instance.WriteLogAdd($"493-->{ex.Message}");
  474. }
  475. }
  476. else if (opcBody.Type == ActionTypeEnum.SynFile.ToString())
  477. {
  478. try
  479. {
  480. Server.MethodCallResult methodCallResult = opcServer.MethodCall("GetAllFiles", UPLOAD_NC_PATH);
  481. if (methodCallResult.status.ToUpper().Equals("GOOD"))
  482. {
  483. responseBody.msg = "同步文件成功";
  484. }
  485. else
  486. {
  487. responseBody.msg = "同步文件失败";
  488. }
  489. // }
  490. }
  491. catch (Exception ex)
  492. {
  493. responseBody.msg = "同步文件失败===>" + ex.Message;
  494. YG.Log.Instance.WriteLogAdd($"{ex.Message}");
  495. }
  496. }
  497. }
  498. else
  499. {
  500. responseBody.code = 0;
  501. responseBody.msg = "服务器离线,连不上opcUa";
  502. responseBody.result = false;
  503. }
  504. YG.Log.Instance.WriteLogAdd("Disconnect!");
  505. response.ContentType = "application/json;charset=UTF-8";
  506. response.ContentEncoding = Encoding.UTF8;
  507. response.AppendHeader("Content-Type", "application/json;charset=UTF-8");
  508. string retJsonData = JsonConvert.SerializeObject(responseBody);
  509. YG.Log.Instance.WriteLogAdd($"WMS--->>{responseBody.Json_SerializeObject()}--->>{body}\r\n");
  510. }
  511. catch (Exception opcex)
  512. {
  513. // 删除map中对应的bean
  514. opcServerMap.Remove(opcBody.ServerUrl);
  515. // 断开连接
  516. if (opcServer.Session != null)
  517. {
  518. opcServer.Disconnect();
  519. }
  520. responseBody.msg = opcex.Message;
  521. responseBody.result = false;
  522. AddList(DateTime.Now.ToString(), "POST", request.Url.ToString(), opcex.Message);
  523. }
  524. finally
  525. {
  526. using (StreamWriter writer = new StreamWriter(response.OutputStream, Encoding.UTF8))
  527. {
  528. writer.Write(responseBody.Json_SerializeObject());
  529. writer.Close();
  530. //response.Close();
  531. }
  532. }
  533. }
  534. }
  535. else if (request.HttpMethod == "GET")
  536. {
  537. if (!request.Url.ToString().Contains("favicon"))
  538. {
  539. string ip = request.QueryString["ip"];
  540. string port = request.QueryString["port"];
  541. string fun = request.QueryString["fun"];
  542. AddList(DateTime.Now.ToString(), "GET", ip + port + fun, "OK");
  543. }
  544. }
  545. response.Close();
  546. }
  547. }
  548. private List<string> readVariables(Server server, string[] variables)
  549. {
  550. List<string> nodeIdStrings = new List<string>();
  551. foreach (string variable in variables)
  552. {
  553. NodeId nodeId = new NodeId(variable, (ushort)2);
  554. nodeIdStrings.Add(nodeId.ToString());
  555. }
  556. return server.ReadValues(nodeIdStrings);
  557. }
  558. private void addAddress(RequestBody opcBody)
  559. {
  560. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX310.0");
  561. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX311.0");
  562. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX311.1");
  563. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX311.2");
  564. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX312.0");
  565. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX312.1");
  566. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX313.7");
  567. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX314.0");
  568. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX314.1");
  569. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX314.2");
  570. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX316.7");
  571. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX326.0");
  572. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX326.1");
  573. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX326.2");
  574. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX326.3");
  575. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX491.0");
  576. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX493.0");
  577. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX493.1");
  578. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX495.0");
  579. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX497.0");
  580. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX497.1");
  581. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX499.0");
  582. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX501.0");
  583. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX501.1");
  584. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.0");
  585. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.1");
  586. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.2");
  587. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.3");
  588. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.4");
  589. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.5");
  590. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.6");
  591. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX554.7");
  592. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.0");
  593. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.1");
  594. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.2");
  595. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.3");
  596. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.4");
  597. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.5");
  598. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.6");
  599. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX555.7");
  600. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.0");
  601. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.1");
  602. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.3");
  603. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.4");
  604. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.6");
  605. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX556.7");
  606. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.0");
  607. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.1");
  608. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.2");
  609. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.3");
  610. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.4");
  611. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX557.5");
  612. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX558.0");
  613. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX558.2");
  614. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX559.0");
  615. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX559.1");
  616. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX559.2");
  617. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX559.3");
  618. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.0");
  619. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.1");
  620. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.2");
  621. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.3");
  622. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.4");
  623. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX560.5");
  624. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX570.0");
  625. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.0");
  626. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.1");
  627. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.2");
  628. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.3");
  629. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.4");
  630. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.5");
  631. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.6");
  632. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX574.7");
  633. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX575.0");
  634. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX575.1");
  635. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX578.0");
  636. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX578.1");
  637. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX578.2");
  638. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX579.0");
  639. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX579.1");
  640. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX579.2");
  641. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX579.3");
  642. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX590.1");
  643. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX590.2");
  644. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX590.3");
  645. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX624.0");
  646. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX624.1");
  647. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX626.0");
  648. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX626.1");
  649. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX626.2");
  650. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX626.3");
  651. opcBody.Addresses.Add("ns=2;s=/Plc/DB2.DBX626.4");
  652. opcBody.Addresses.Add("ns=2;s=/Plc/DB10.DBX106.1");
  653. /*opcBody.Addresses.Add("ns=2;s=/Nck/SequencedAlarms/timeBCD");
  654. opcBody.Addresses.Add("ns=2;s=/Nck/SequencedAlarms/textIndex");*/
  655. opcBody.Addresses.Add("ns=2;s=/Channel/GeometricAxis/feedRateOvr");
  656. opcBody.Addresses.Add("ns=2;s=/Channel/Spindle/speedOvr");
  657. opcBody.Addresses.Add("ns=2;s=/Channel/Spindle/actSpeed");
  658. opcBody.Addresses.Add("ns=2;s=/Channel/MachineAxis/vaLoad");
  659. opcBody.Addresses.Add("ns=2;s=/Nck/ChannelDiagnose/setupTime");
  660. opcBody.Addresses.Add("ns=2;s=/Channel/ChannelDiagnose/operatingTime");
  661. opcBody.Addresses.Add("ns=2;s=/Channel/ProgramInfo/selectedWorkPProg");
  662. }
  663. public class DeviceInfo
  664. {
  665. public string ConnectMsg
  666. { get; set; }
  667. public string ConnectErrorMsg
  668. { get; set; }
  669. public string CncSoftVersion
  670. { get; set; }
  671. public string CncType
  672. { get; set; }
  673. public string CncId
  674. { get; set; }
  675. public string CncMode
  676. { get; set; }
  677. public string RunStatus
  678. { get; set; }
  679. public string Products
  680. { get; set; }
  681. public string CycleTime
  682. { get; set; }
  683. public string RemainTime
  684. { get; set; }
  685. public string MainProg
  686. { get; set; }
  687. public string SetFeedSpeed
  688. { get; set; }
  689. public string ActFeedSpeed
  690. { get; set; }
  691. public string SetSpSpeed
  692. { get; set; }
  693. public string ActSpSpeed
  694. { get; set; }
  695. public string AxisName
  696. { get; set; }
  697. public string FeedRate
  698. { get; set; }
  699. public string SpRate
  700. { get; set; }
  701. public string MaxPos1
  702. { get; set; }
  703. public string MaxPos2
  704. { get; set; }
  705. public string MaxPos3
  706. { get; set; }
  707. public string RelPos1
  708. { get; set; }
  709. public string RelPos2
  710. { get; set; }
  711. public string RelPos3
  712. { get; set; }
  713. public string RemainPos1
  714. { get; set; }
  715. public string RemainPos2
  716. { get; set; }
  717. public string RemainPos3
  718. { get; set; }
  719. public string ToolNo
  720. { get; set; }
  721. public string LenthX
  722. { get; set; }
  723. public string LenthZ
  724. { get; set; }
  725. public string RadiusCompenNum
  726. { get; set; }
  727. public string LengthCompenNum
  728. { get; set; }
  729. public string ToolAbradeRadius
  730. { get; set; }
  731. public string ToolEdgePos
  732. { get; set; }
  733. public string IsAlarm
  734. { get; set; }
  735. public List<AlmInfo> AlmMsg { get; set; } = new List<AlmInfo>();
  736. public string ToolLife
  737. { get; set; }
  738. }
  739. public class AlmInfo
  740. {
  741. public string no { get; set; }
  742. public string msg { get; set; }
  743. }
  744. public class Servlet
  745. {
  746. public virtual void onGet(System.Net.HttpListenerRequest request, System.Net.HttpListenerResponse response, string info) { }
  747. public virtual void onPost(System.Net.HttpListenerRequest request, System.Net.HttpListenerResponse response) { }
  748. public virtual void onCreate()
  749. {
  750. }
  751. }
  752. public void AddList(string dtime, string type, string url, string res)
  753. {
  754. this.Invoke(new Action(delegate ()
  755. {
  756. listView1.BeginUpdate(); //数据更新,UI暂时挂起,直到EndUpdate绘制控件,可以有效避免闪烁并大大提高加载速度
  757. ListViewItem lvi = new ListViewItem();
  758. lvi.Text = dtime;
  759. lvi.SubItems.Add(type);
  760. lvi.SubItems.Add(url);
  761. lvi.SubItems.Add(res);
  762. this.listView1.Items.Insert(0, lvi);
  763. if (this.listView1.Items.Count > 100)
  764. {
  765. this.listView1.Items.Clear();
  766. }
  767. this.listView1.EndUpdate(); //结束数据处理,UI界面一次性绘制。}
  768. }));
  769. }
  770. public class MyServlet : Servlet
  771. {
  772. public override void onCreate()
  773. {
  774. base.onCreate();
  775. }
  776. public override void onGet(HttpListenerRequest request, HttpListenerResponse response, string info)
  777. {
  778. Console.WriteLine("GET:" + request.Url);
  779. byte[] buffer = Encoding.UTF8.GetBytes(info);
  780. //string sss = request.QueryString["ty"];
  781. System.IO.Stream output = response.OutputStream;
  782. output.Write(buffer, 0, buffer.Length);
  783. // You must close the output stream.
  784. output.Close();
  785. //listener.Stop();
  786. }
  787. public override void onPost(HttpListenerRequest request, HttpListenerResponse response)
  788. {
  789. Console.WriteLine("POST:" + request.Url);
  790. byte[] res = Encoding.UTF8.GetBytes("OK");
  791. response.OutputStream.Write(res, 0, res.Length);
  792. }
  793. }
  794. }
  795. }