MesController.cs 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680
  1. using LocalhostMES.Core;
  2. using LocalhostMES.DataBase;
  3. using LocalhostMES.Helpers;
  4. using LocalhostMES.Models;
  5. using Newtonsoft.Json;
  6. using System;
  7. using System.Collections.Generic;
  8. using System.Linq;
  9. using System.Threading;
  10. using System.Threading.Tasks;
  11. using System.Web.Http;
  12. namespace LocalhostMES.Api.Controllers
  13. {
  14. [RoutePrefix("api/mes")]
  15. public class MesController : ApiController
  16. {
  17. private static int _snCounter = 1;
  18. private Management management;
  19. public MesController()
  20. {
  21. management = Management.GetManagement();
  22. }
  23. #region 2.1 厂级MES下发工单信息
  24. [HttpPost]
  25. [Route("receiveWorkOrder")]
  26. public IHttpActionResult ReceiveWorkOrder([FromBody] WorkOrderRequest request)
  27. {
  28. try
  29. {
  30. LogHelper.WriteLogInfo("厂级MES下发工单信息");
  31. // 验证必填字段
  32. if ( string.IsNullOrEmpty(request.WorkOrderNo) ||
  33. string.IsNullOrEmpty(request.MaterialCode) ||
  34. string.IsNullOrEmpty(request.MaterialName) ||
  35. string.IsNullOrEmpty(request.LineCode) )
  36. {
  37. LogHelper.WriteLogInfo("必填字段不能为空");
  38. return BadRequest("必填字段不能为空");
  39. }
  40. // 工单状态验证
  41. if ( !IsValidStatus(request.Status) )
  42. {
  43. LogHelper.WriteLogInfo("无效的工单状态");
  44. return BadRequest($"无效的工单状态: {request.Status}");
  45. }
  46. // 创建或更新工单信息
  47. var workOrder = new WorkOrderInfo
  48. {
  49. WorkOrderNo = request.WorkOrderNo,
  50. MaterialCode = request.MaterialCode,
  51. OrderNo = request.OrderNo,
  52. MaterialName = request.MaterialName,
  53. PlannedQuantity = int.TryParse(request.WorkOrderNum, out var qty) ? qty : 0,
  54. CompletedQuantity = 0,
  55. Status = request.Status,
  56. LineCode = request.LineCode,
  57. CreateTime = DateTime.Now,
  58. StartTime = DateTime.Now.AddSeconds(2),
  59. EndTime = DateTime.Now.AddSeconds(5)
  60. };
  61. if ( DatabaseHelper.InsertWorkOrderInfo(workOrder) )
  62. {
  63. var response = new ApiResponse<bool>
  64. {
  65. code = "200",
  66. success = true,
  67. msg = "工单接收成功",
  68. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  69. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  70. data = true
  71. };
  72. LogHelper.WriteLogInfo("工单接收成功");
  73. return Ok(response);
  74. }
  75. else
  76. {
  77. var errorResponse = new ErrorResponse
  78. {
  79. code = "55000",
  80. success = false,
  81. msg = $"工单接收失败:数据库插入异常",
  82. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  83. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  84. };
  85. LogHelper.WriteLogInfo("数据库插入异常");
  86. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  87. }
  88. }
  89. catch ( Exception ex )
  90. {
  91. var errorResponse = new ErrorResponse
  92. {
  93. code = "55000",
  94. success = false,
  95. msg = $"工单接收失败: {ex.Message}",
  96. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  97. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  98. };
  99. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  100. }
  101. }
  102. [HttpGet]
  103. [Route("getWorkOrders")]
  104. public IHttpActionResult GetWorkOrders()
  105. {
  106. try
  107. {
  108. LogHelper.WriteLogInfo("接口getWorkOrders收到消息");
  109. var workOrders = DatabaseHelper.SelectWorkOrderInfo(null);
  110. var response = new ApiResponse<List<WorkOrderInfo>>
  111. {
  112. code = "200",
  113. success = true,
  114. msg = "获取成功",
  115. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  116. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  117. data = workOrders
  118. };
  119. return Ok(response);
  120. }
  121. catch ( Exception ex )
  122. {
  123. var errorResponse = new ErrorResponse
  124. {
  125. code = "55000",
  126. success = false,
  127. msg = $"获取工单失败: {ex.Message}",
  128. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  129. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  130. };
  131. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  132. }
  133. }
  134. #endregion
  135. #region 2.2 SN打印请求
  136. [HttpPost]
  137. [Route("requestSnPrint")]
  138. public async Task<IHttpActionResult> RequestSnPrint([FromBody] SnPrintRequest request)
  139. {
  140. try
  141. {
  142. // 验证请求头
  143. if ( !ValidateHeaders() )
  144. {
  145. return Unauthorized();
  146. }
  147. // 验证必填字段
  148. if ( string.IsNullOrEmpty(request.workOrderNo) || request.count <= 0 )
  149. {
  150. return BadRequest("工单号和数量为必填项且数量必须大于0");
  151. }
  152. var workOrder = DatabaseHelper.SelectWorkOrderInfo(request.workOrderNo);
  153. // 验证工单是否存在
  154. if ( workOrder.Count == 0 )
  155. {
  156. return BadRequest($"工单 {request.workOrderNo} 不存在");
  157. }
  158. // 验证打印类型
  159. if ( request.printType < 1 || request.printType > 4 )
  160. {
  161. return BadRequest($"无效的打印类型: {request.printType}");
  162. }
  163. LogHelper.WriteLogInfo("请求参数:");
  164. LogHelper.WriteLogInfo(JsonConvert.SerializeObject(request, Formatting.Indented));
  165. if ( workOrder[0].IsLocalhost)
  166. {
  167. var Manualsninfo = DatabaseHelper.SelectSnInfo(request.workOrderNo);
  168. DatabaseHelper.InsertSnInfo(new SnInfo()
  169. {
  170. Sn = "000001" + DateCodeConverter.GetYearCode(DateTime.Now.Year) +
  171. DateCodeConverter.GetMonthCode(DateTime.Now.Month) +
  172. DateCodeConverter.GetDayCode(DateTime.Now.Day) +
  173. "00000" + Manualsninfo.Count,
  174. IsUsed = false,
  175. WorkOrderNo = request.workOrderNo,
  176. GenerateTime = DateTime.Now,
  177. PrintType = "1",
  178. });
  179. }
  180. else
  181. {
  182. var hassninfo = DatabaseHelper.SelectSnInfo(request.workOrderNo, true, false);
  183. if (hassninfo.Count == 0)
  184. {
  185. ApiResponse<SnPrintResponseData> mesres = await management.ApiClient.RequestSnPrintAsync(request);
  186. if (mesres.success && mesres.data != null && mesres.data.Sn.Count != 0)
  187. {
  188. for (int i = 0; i < mesres.data.Sn.Count; i++)
  189. {
  190. if (!DatabaseHelper.InsertSnInfo(new SnInfo()
  191. {
  192. WorkOrderNo = mesres.data.WorkOrderNo,
  193. Sn = mesres.data.Sn[i].Sn,
  194. GenerateTime = DateTime.Now,
  195. PrintType = "1",
  196. IsUsed = false,
  197. }))
  198. {
  199. mesres.msg = "插入SN到数据库出错";
  200. mesres.success = false;
  201. return Content(System.Net.HttpStatusCode.InternalServerError, mesres);
  202. }
  203. }
  204. return Ok(mesres);
  205. }
  206. return Content(System.Net.HttpStatusCode.InternalServerError, mesres);
  207. }
  208. }
  209. var sninfo = DatabaseHelper.SelectSnInfo(request.workOrderNo, true, false);
  210. // 生成SN列表
  211. var snList = new List<SnItem>();
  212. if ( sninfo.Count != 0 )
  213. {
  214. snList.Add(new SnItem { Sn = sninfo[ 0 ].Sn });
  215. var responseData = new SnPrintResponseData
  216. {
  217. Sn = snList,
  218. OrderNo = request.orderNo ?? "",
  219. WorkOrderNo = request.workOrderNo,
  220. Line = request.line ?? "",
  221. VehicleCode = workOrder[0].MaterialCode,
  222. MaterialDesc = workOrder[0].MaterialName
  223. };
  224. var response = new ApiResponse<SnPrintResponseData>
  225. {
  226. code = "200",
  227. success = true,
  228. msg = "SN生成成功",
  229. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  230. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  231. data = responseData
  232. };
  233. return Ok(response);
  234. }
  235. var errorResponse = new ErrorResponse
  236. {
  237. code = "55000",
  238. success = false,
  239. msg = $"SN获取失败",
  240. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  241. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  242. };
  243. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  244. }
  245. catch ( Exception ex )
  246. {
  247. var errorResponse = new ErrorResponse
  248. {
  249. code = "55000",
  250. success = false,
  251. msg = $"SN生成失败: {ex.Message}",
  252. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  253. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  254. };
  255. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  256. }
  257. }
  258. [HttpGet]
  259. [Route("getSns/{workOrderNo}")]
  260. public IHttpActionResult GetSns(string workOrderNo)
  261. {
  262. try
  263. {
  264. var sninfo = DatabaseHelper.SelectSnInfo(workOrderNo, true, false);
  265. if ( sninfo.Count != 0 )
  266. {
  267. var response = new ApiResponse<List<SnInfo>>
  268. {
  269. code = "200",
  270. success = true,
  271. msg = "获取成功",
  272. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  273. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  274. data = sninfo
  275. };
  276. return Ok(response);
  277. }
  278. var errorResponse = new ErrorResponse
  279. {
  280. code = "55001",
  281. success = false,
  282. msg = $"工单 {workOrderNo} 没有SN记录",
  283. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  284. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  285. };
  286. return Content(System.Net.HttpStatusCode.NotFound, errorResponse);
  287. }
  288. catch ( Exception ex )
  289. {
  290. var errorResponse = new ErrorResponse
  291. {
  292. code = "55000",
  293. success = false,
  294. msg = $"获取SN失败: {ex.Message}",
  295. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  296. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  297. };
  298. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  299. }
  300. }
  301. #endregion
  302. #region 2.3 接收SN和关键件
  303. [HttpPost]
  304. [Route("receiveSnComponent")]
  305. public async Task<IHttpActionResult> ReceiveSnComponent([FromBody] SnKeyComponentRequest request)
  306. {
  307. try
  308. {
  309. LogHelper.WriteLogInfo($"收到请求: 接收SN和关键件");
  310. var res= DatabaseHelper.SelectWorkOrderInfo();
  311. var workOrder = DatabaseHelper.SelectWorkOrderInfo(res.LeftOrderNo);
  312. // 验证工单是否存在
  313. if ( workOrder.Count == 0 )
  314. {
  315. return BadRequest($"工单 {res.LeftOrderNo} 不存在");
  316. }
  317. if ( workOrder[0].IsLocalhost )
  318. {
  319. return Ok(new ApiResponse<bool?>() { data = true });
  320. }
  321. // 验证请求头
  322. if ( !ValidateHeaders() )
  323. {
  324. return Unauthorized();
  325. }
  326. // 验证必填字段
  327. if ( string.IsNullOrEmpty(request.plant) ||
  328. string.IsNullOrEmpty(request.stationCode) ||
  329. string.IsNullOrEmpty(request.positionCode) ||
  330. string.IsNullOrEmpty(request.sn) ||
  331. string.IsNullOrEmpty(request.scanTime) )
  332. {
  333. return BadRequest("必填字段不能为空");
  334. }
  335. // 处理关键件绑定
  336. if ( request.part != null && request.part.Count > 0 )
  337. {
  338. foreach ( var part in request.part )
  339. {
  340. if ( string.IsNullOrEmpty(part.partNum) )
  341. {
  342. return BadRequest("关键件条码不能为空");
  343. }
  344. var bindRecord = new BindRecord
  345. {
  346. Sn = request.sn,
  347. PartNum = part.partNum,
  348. StationCode = request.stationCode,
  349. BindTime = DateTime.TryParse(request.scanTime, out var scanTime) ? scanTime : DateTime.Now,
  350. Employee = request.employee ?? "",
  351. ScanType = request.scanTpye
  352. };
  353. DatabaseHelper.InsertBindRecord(bindRecord);
  354. if ( workOrder[ 0 ].IsLocalhost )
  355. {
  356. //if (DatabaseHelper.GetProductProductionRecords(request.sn) == 0)
  357. //{
  358. var response = new ApiResponse<bool>
  359. {
  360. code = "200",
  361. success = true,
  362. msg = "已存在记录",
  363. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  364. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  365. data = true
  366. };
  367. return Ok(response);
  368. }
  369. }
  370. }
  371. else
  372. {
  373. var bindRecord = new BindRecord
  374. {
  375. Sn = request.sn,
  376. PartNum ="",
  377. StationCode = request.stationCode,
  378. BindTime = DateTime.TryParse(request.scanTime, out var scanTime) ? scanTime : DateTime.Now,
  379. Employee = request.employee ?? "",
  380. ScanType = request.scanTpye
  381. };
  382. DatabaseHelper.InsertBindRecord(bindRecord);
  383. }
  384. if ( workOrder[ 0 ].IsLocalhost )
  385. {
  386. LogHelper.WriteLogInfo($"收到请求: 接收SN和关键件 成功");
  387. return Ok(new ApiResponse<bool?>() { data = true });
  388. }
  389. var okresponse = await management.ApiClient.SendSnComponentAsync(request);
  390. if ( okresponse.success && okresponse.code == "200" )
  391. {
  392. LogHelper.WriteLogInfo($"收到请求: 接收SN和关键件 成功");
  393. return Ok(okresponse);
  394. }
  395. else
  396. {
  397. LogHelper.WriteLogInfo($"收到请求: 接收SN和关键件 失败\r\n" + okresponse.ToString());
  398. okresponse.success = false;
  399. return Content(System.Net.HttpStatusCode.InternalServerError, okresponse);
  400. }
  401. }
  402. catch ( Exception ex )
  403. {
  404. var errorResponse = new ErrorResponse
  405. {
  406. code = "55000",
  407. success = false,
  408. msg = $"SN和关键件接收失败: {ex.Message}",
  409. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  410. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  411. };
  412. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  413. }
  414. }
  415. [HttpGet]
  416. [Route("getBindRecords")]
  417. public IHttpActionResult GetBindRecords()
  418. {
  419. try
  420. {
  421. var records = DatabaseHelper.SelectBindRecord();
  422. var response = new ApiResponse<List<BindRecord>>
  423. {
  424. code = "200",
  425. success = true,
  426. msg = "获取成功",
  427. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  428. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  429. data = records
  430. };
  431. return Ok(response);
  432. }
  433. catch ( Exception ex )
  434. {
  435. var errorResponse = new ErrorResponse
  436. {
  437. code = "55000",
  438. success = false,
  439. msg = $"获取绑定记录失败: {ex.Message}",
  440. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  441. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  442. };
  443. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  444. }
  445. }
  446. #endregion
  447. #region 2.4 接收工件加工参数
  448. [HttpPost]
  449. [Route("receiveProcessParameters")]
  450. public async Task<IHttpActionResult> ReceiveProcessParameters([FromBody] ProcessParameterRequest request)
  451. {
  452. try
  453. {
  454. LogHelper.WriteLogInfo($"收到请求:接收工件加工参数 ");
  455. var res= DatabaseHelper.SelectWorkOrderInfo();
  456. var workOrder = DatabaseHelper.SelectWorkOrderInfo(res.LeftOrderNo);
  457. // 验证工单是否存在
  458. if ( workOrder.Count == 0 )
  459. {
  460. return BadRequest($"工单 {res.LeftOrderNo} 不存在");
  461. }
  462. // 验证请求头
  463. if ( !ValidateHeaders() )
  464. {
  465. return Unauthorized();
  466. }
  467. // 验证必填字段
  468. if ( string.IsNullOrEmpty(request.plant) ||
  469. string.IsNullOrEmpty(request.station) ||
  470. string.IsNullOrEmpty(request.sn) ||
  471. string.IsNullOrEmpty(request.overallResult) )
  472. {
  473. return BadRequest("必填字段不能为空");
  474. }
  475. // 验证总结果
  476. if ( request.overallResult != "OK" && request.overallResult != "NG" )
  477. {
  478. return BadRequest($"无效的总结果: {request.overallResult}");
  479. }
  480. // 保存加工记录
  481. var processRecord = new ProcessRecord
  482. {
  483. Sn = request.sn,
  484. Station = request.station,
  485. OverallResult = request.overallResult,
  486. ProcessTime = DateTime.Now,
  487. Equipment = request.equipment ?? ""
  488. };
  489. DatabaseHelper.InsertProcessRecord(processRecord);
  490. if ( workOrder[ 0 ].IsLocalhost )
  491. {
  492. var response = new ApiResponse<bool>
  493. {
  494. code = "200",
  495. success = true,
  496. msg = "加工参数接收成功",
  497. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  498. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  499. data = true
  500. };
  501. LogHelper.WriteLogInfo($"收到请求:接收工件加工参数 成功");
  502. return Ok(response);
  503. }
  504. var okresponse = await management.ApiClient.SendProcessParametersAsync(request);
  505. if ( okresponse.success && okresponse.code == "200" )
  506. {
  507. LogHelper.WriteLogInfo($"收到请求: 接收工件加工参数 成功");
  508. return Ok(okresponse);
  509. }
  510. else
  511. {
  512. LogHelper.WriteLogInfo($"收到请求: 接收工件加工参数 失败\r\n" + okresponse.ToString());
  513. okresponse.success = false;
  514. return Content(System.Net.HttpStatusCode.InternalServerError, okresponse);
  515. }
  516. }
  517. catch ( Exception ex )
  518. {
  519. LogHelper.WriteLogInfo("出错");
  520. var errorResponse = new ErrorResponse
  521. {
  522. code = "55000",
  523. success = false,
  524. msg = $"加工参数接收失败: {ex.Message}",
  525. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  526. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  527. };
  528. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  529. }
  530. }
  531. [HttpGet]
  532. [Route("getProcessRecords")]
  533. public IHttpActionResult GetProcessRecords()
  534. {
  535. try
  536. {
  537. var records = DatabaseHelper.SelectProcessRecord();
  538. var response = new ApiResponse<List<ProcessRecord>>
  539. {
  540. code = "200",
  541. success = true,
  542. msg = "获取成功",
  543. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  544. traceId = Guid.NewGuid().ToString("N").Substring(0, 24),
  545. data = records
  546. };
  547. return Ok(response);
  548. }
  549. catch ( Exception ex )
  550. {
  551. var errorResponse = new ErrorResponse
  552. {
  553. code = "55000",
  554. success = false,
  555. msg = $"获取加工记录失败: {ex.Message}",
  556. msgTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
  557. traceId = Guid.NewGuid().ToString("N").Substring(0, 24)
  558. };
  559. return Content(System.Net.HttpStatusCode.InternalServerError, errorResponse);
  560. }
  561. }
  562. #endregion
  563. #region 辅助方法
  564. private bool ValidateHeaders()
  565. {
  566. // 简单的token验证
  567. if ( Request.Headers.TryGetValues("app-key", out var appKeyValues) &&
  568. Request.Headers.TryGetValues("token", out var tokenValues) )
  569. {
  570. var appKey = appKeyValues.FirstOrDefault();
  571. var token = tokenValues.FirstOrDefault();
  572. // 这里使用简单的验证
  573. return appKey == "test-app-key" && token == "test-token-123";
  574. }
  575. return false;
  576. }
  577. private bool IsValidStatus(string status)
  578. {
  579. var validStatuses = new[] { "0", "1", "2", "3", "4", "5", "6", "7" };
  580. return validStatuses.Contains(status);
  581. }
  582. private string GenerateSn(WorkOrderInfo workOrder, int printType)
  583. {
  584. var prefix = GetPrintTypePrefix(printType);
  585. var timestamp = DateTime.Now.ToString("yyMMddHHmm");
  586. var randomStr = Guid.NewGuid().ToString("N").Substring(0, 6).ToUpper();
  587. var counter = Interlocked.Increment(ref _snCounter);
  588. return $"{prefix}-{workOrder.MaterialCode}-{timestamp}-{counter:D4}-{randomStr}";
  589. }
  590. private string GetPrintTypePrefix(int printType)
  591. {
  592. switch ( printType )
  593. {
  594. case 1:
  595. return "P";
  596. case 2:
  597. return "C";
  598. case 3:
  599. return "Q";
  600. case 4:
  601. return "B";
  602. default:
  603. return "U";
  604. }
  605. }
  606. private string GetPrintTypeName(int printType)
  607. {
  608. switch ( printType )
  609. {
  610. case 1:
  611. return "产品码";
  612. case 2:
  613. return "零件码";
  614. case 3:
  615. return "合格码";
  616. case 4:
  617. return "装箱码";
  618. default:
  619. return "未知";
  620. }
  621. }
  622. #endregion
  623. }
  624. }