MachineController.java 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. package com.iamberry.rst.controllers.pts;
  2. import com.iamberry.rst.core.pts.*;
  3. import com.iamberry.rst.core.tools.QRCJson;
  4. import com.iamberry.rst.core.tools.WeixinUtil;
  5. import com.iamberry.rst.faces.pts.*;
  6. import com.iamberry.wechat.tools.NameUtils;
  7. import com.iamberry.wechat.tools.ResponseJson;
  8. import com.iamberry.wechat.tools.ResultInfo;
  9. import net.sf.json.JSONArray;
  10. import net.sf.json.JSONObject;
  11. import org.springframework.beans.factory.annotation.Autowired;
  12. import org.springframework.stereotype.Controller;
  13. import org.springframework.web.bind.annotation.RequestBody;
  14. import org.springframework.web.bind.annotation.RequestMapping;
  15. import org.springframework.web.bind.annotation.ResponseBody;
  16. import javax.servlet.http.HttpServletRequest;
  17. import java.util.Date;
  18. import java.util.Iterator;
  19. import java.util.List;
  20. /**
  21. * Created by LJK on 2017/8/29.
  22. */
  23. @Controller
  24. @RequestMapping("/mcahine")
  25. public class MachineController {
  26. @Autowired
  27. private ProduceService produceService;
  28. @Autowired
  29. private MachineService machineService;
  30. @Autowired
  31. private DeviceService deviceService;
  32. @Autowired
  33. private PtsEmployeeService ptsEmployeeService;
  34. @Autowired
  35. private MachineLogsService machineLogsService;
  36. @ResponseBody
  37. @RequestMapping("/uploadProcessOptions")
  38. public ResponseJson uploadProcessOptions(HttpServletRequest request,@RequestBody JSONObject query){
  39. ResponseJson rj = new ResponseJson();
  40. if(query == null){
  41. rj.setResultMsg("200");
  42. rj.setResultMsg("ERROR");
  43. return rj;
  44. }
  45. Integer employeeId = query.getInt("employeeId");//员工id
  46. String produceNo = query.getString("produceId");//产品编号
  47. //生成条形码,二维码
  48. String berQrcode = String.valueOf(employeeId+new Date().getTime());
  49. String json = String.format(NameUtils.QR_LIMIT_STR_SCENE, ResultInfo.barCodePrefix+berQrcode);
  50. QRCJson qrc = WeixinUtil.createQrcode(json);
  51. PtsMachine ptsMachine = new PtsMachine();
  52. if (!(qrc == null || qrc.getUrl() == null || qrc.getUrl().isEmpty())) {
  53. ptsMachine.setMachineQrcode(qrc.getUrl());//二维码
  54. ptsMachine.setMachineBarcode(berQrcode);//条形码
  55. ptsMachine.setMachineStatus(1);//机器状态
  56. ptsMachine.setMachineProducedTime(new Date());//生产时间
  57. ptsMachine.setMachineIsPrint(1);//是否打印1:未打印2:已打印
  58. ptsMachine.setMachineCompoundImg("合成的图片url");
  59. ptsMachine.setMachineProcessState(1);//生成流程状态1.正常2.异常
  60. ptsMachine.setMachineCreateTime(new Date());//创建时间
  61. machineService.addMachine(ptsMachine);
  62. }
  63. boolean isAbnormality = true;//状态是否异常
  64. JSONArray nodes = query.getJSONArray("nodes");//选项集合(包含一个或多个工序选项,详情见示例)
  65. Iterator<Object> it = nodes.iterator();
  66. for(int i = 0;i< nodes.size();i++){
  67. JSONObject jsonObject = nodes.getJSONObject(i);
  68. String processNo = jsonObject.getString("processId"); //工序编号
  69. String nodeNo = jsonObject.getString("nodeId"); //工序选项编号
  70. Long logsProcessTime = jsonObject.getLong("logsProcessTime"); //工序执行时间 (时间戳)
  71. Date logsProcessDate = new Date(logsProcessTime);
  72. Produce produce = produceService.getProduce(produceNo);//根据产品编号获取产品信息
  73. ProduceProcess produceProcess = produceService.getProduceProcess(produce.getProduceId(),processNo.charAt(0));
  74. ProcessNode processNode = produceService.getprocessNode(produceProcess.getProcessId(),nodeNo.charAt(0));
  75. PtsDevice ptsDevice = deviceService.getDevice(produceProcess.getDriveId());
  76. PtsEmployee ptsEmployee =ptsEmployeeService.getPtsEmployeeById(employeeId);
  77. PtsMachineLogs ptsMachineLogs = new PtsMachineLogs();
  78. ptsMachineLogs.setDeviceId(produceProcess.getDriveId());
  79. ptsMachineLogs.setEmployeeId(employeeId);
  80. ptsMachineLogs.setProduceId(produce.getProduceId());
  81. ptsMachineLogs.setProcessId(produceProcess.getProcessId());
  82. ptsMachineLogs.setMachineId(ptsMachine.getMachineId());
  83. ptsMachineLogs.setEmployeeName(ptsEmployee.getEmployeeName());
  84. ptsMachineLogs.setProduceName(produce.getProduceName());
  85. ptsMachineLogs.setProcessName(produceProcess.getProcessName());
  86. ptsMachineLogs.setDeviceName(ptsDevice.getDeviceName());
  87. if(i == 0){//如果当前循环的是第一条数据则排序必须是1,否则为异常
  88. if(produceProcess.getProcessSort() == 1){
  89. if(processNode.getNodeStatus() == 0){//工序选项状态为异常则机器表状态也是异常
  90. isAbnormality = false;
  91. }
  92. ptsMachineLogs.setLogsProcessStatus(processNode.getNodeStatus());
  93. }else{
  94. ptsMachineLogs.setLogsProcessStatus(0);
  95. isAbnormality = false;
  96. }
  97. }else{//默认为正常
  98. ptsMachineLogs.setLogsProcessStatus(1);
  99. }
  100. ptsMachineLogs.setLogsProcessPrompt(processNode.getNodeStatus() == 0?"异常操作": null);
  101. ptsMachineLogs.setLogsProcessTime(logsProcessDate);
  102. ptsMachineLogs.setLogsCreateTime(new Date());
  103. //根据上一条工序选项信息判断当前工序是否正常,如果当前为修理工序则忽略,如果上一条为修理工序则查询上上一条
  104. if(i > 0){
  105. //查询出当前产品正常生产工序
  106. //List<ProduceProcess> ProcessList = produceService.listProduceProcess(produce.getProduceId());
  107. int num = 0;
  108. ProduceProcess produceProcess2 = null;//当前工序的上一条非修理工序
  109. JSONObject jsonObject2;//上一级工序信息
  110. String processNo2 = null;//上一级工序编号
  111. //先判断当前的上一次是否是修理工序,如果不是则不用执行下面的循环,否则需要循环判断
  112. jsonObject2 = nodes.getJSONObject(i-1);
  113. if(jsonObject2 != null){
  114. processNo2 = jsonObject.getString("processId");
  115. produceProcess2 = produceService.getProduceProcess(produce.getProduceId(),processNo2.charAt(0));
  116. if(produceProcess2.getProcessType() == 1){//判断是否是修理工序 1:生产工序 2:修理工序
  117. if(produceProcess.getProcessSort() - produceProcess2.getProcessSort() != 1){
  118. ptsMachineLogs.setLogsProcessStatus(0);
  119. ptsMachineLogs.setLogsErrorType(1);//异常类型 1:流程异常 2:次品异常
  120. isAbnormality = false;
  121. }
  122. }else{
  123. for(int j = i-1;j<= i-1;j--){
  124. if(num == i){
  125. break;//只能循环 i 次,超出则跳出当前循环
  126. }
  127. jsonObject2 = nodes.getJSONObject(j);
  128. if(jsonObject2 != null){
  129. processNo2 = jsonObject.getString("processId");
  130. produceProcess2 = produceService.getProduceProcess(produce.getProduceId(),processNo2.charAt(0));
  131. if(produceProcess2.getProcessType() == 1){//判断是否是修理工序 1:生产工序 2:修理工序
  132. break;
  133. }else{
  134. if(produceProcess.getProcessSort() > produceProcess2.getProcessSort()){
  135. ptsMachineLogs.setLogsProcessStatus(0);
  136. ptsMachineLogs.setLogsErrorType(1);//异常类型 1:流程异常 2:次品异常
  137. isAbnormality = false;
  138. }
  139. }
  140. }
  141. num++;
  142. }
  143. }
  144. }
  145. }
  146. //执行添加日志操作
  147. machineLogsService.addMachineLogs(ptsMachineLogs);
  148. }
  149. //修改机器信息
  150. if(isAbnormality){
  151. PtsMachine ptsMachine2 = new PtsMachine();
  152. ptsMachine2.setMachineId(ptsMachine.getMachineId());
  153. ptsMachine2.setMachineProcessState(2);//2表示机器生产过程中出现异常
  154. ptsMachine2.setMachineUpdateTime(new Date());
  155. machineService.updateMachine(ptsMachine2);
  156. }
  157. //截取条形码尾号(4位)
  158. rj.addResponseKeyValue("barcodeTail",berQrcode.substring(berQrcode.length()-4, berQrcode.length()));
  159. return rj;
  160. }
  161. }