| | |
| | | private static final boolean DEBUG = false;//调试模式 |
| | | |
| | | private List<JSONObject> socketReadResults = new ArrayList<>(); |
| | | private List<JSONObject> socketResults = new ArrayList<>(); |
| | | private List<DeviceMsgModel> socketResults = new ArrayList<>(); |
| | | |
| | | //原始设备数据 |
| | | private Object originDeviceData; |
| | |
| | | data.put("originDeviceData", deviceMsg.getDeviceOriginMsg()); |
| | | socketReadResults.add(data); |
| | | } else { |
| | | socketResults.add(data);//添加数据 |
| | | socketResults.add(deviceMsg);//添加数据 |
| | | } |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | } |
| | | |
| | | public JSONObject getRequestBody(String type, String taskId) { |
| | | public JSONObject getRequestBody(String resultKey) { |
| | | try { |
| | | // 获取服务器响应 |
| | | JSONObject result = null; |
| | | if (type.equals("readState")) { |
| | | type = "state"; |
| | | } |
| | | |
| | | int idx = -1; |
| | | for (int i = 0; i < socketResults.size(); i++) { |
| | | JSONObject socketResult = socketResults.get(i); |
| | | if (!socketResult.get("msgType").equals("responseMsg")) {//不是响应内容 |
| | | continue; |
| | | } |
| | | |
| | | JSONObject resultResponse = JSON.parseObject(socketResult.get("response").toString()); |
| | | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); |
| | | String responseType = resultBody.get("responseType").toString(); |
| | | if (DEBUG) { |
| | | result = socketResult; |
| | | DeviceMsgModel deviceMsgModel = socketResults.get(i); |
| | | if(deviceMsgModel.getResultKey().equals(resultKey)){ |
| | | idx = i; |
| | | result = JSON.parseObject(JSON.toJSONString(deviceMsgModel.getDeviceMsg())); |
| | | break; |
| | | } |
| | | |
| | | if (!responseType.equals(type)) { |
| | | continue;//响应类型与请求类型不一致,不在调试模式下 |
| | | } |
| | | |
| | | if (taskId != null) { |
| | | String responseTaskId = resultBody.get("taskId").toString(); |
| | | if (!responseTaskId.equals(taskId)) { |
| | | continue;//响应ID与请求ID不一致,不在调试模式下 |
| | | } |
| | | } |
| | | |
| | | result = socketResult; |
| | | break; |
| | | } |
| | | |
| | | if (result == null) { |
| | | return null;//无响应结果 |
| | | } |
| | | |
| | | socketResults.remove(idx); |
| | | return filterBodyData(result);//返回Body结果集 |
| | | } catch (Exception e) { |
| | | return null; |
| | |
| | | } |
| | | |
| | | NyShuttleHttpCommand readStatusCommand = getReadStatusCommand(deviceConfig.getDeviceNo()); |
| | | //指令超过五条,不再下发任务状态请求 |
| | | //指令超过2条,不再下发任务状态请求 |
| | | TreeSet<String> deviceCommandMsgListKey = deviceMsgUtils.getDeviceCommandMsgListKey(SlaveType.Shuttle, deviceConfig.getDeviceNo()); |
| | | if (deviceCommandMsgListKey.size() < 5) { |
| | | requestCommandAsync(readStatusCommand);//请求状态 |
| | | if (deviceCommandMsgListKey.size() < 2) { |
| | | requestCommand(readStatusCommand);//请求状态 |
| | | } |
| | | |
| | | if (this.socketReadResults.isEmpty()) { |
| | |
| | | // 获取服务器响应 |
| | | JSONObject result = null; |
| | | int removeIdx = -1; |
| | | JSONObject socketResult = null; |
| | | for (int i = 0; i < socketResults.size(); i++) { |
| | | JSONObject socketResult = socketResults.get(i); |
| | | if (socketResult == null) { |
| | | DeviceMsgModel deviceMsgModel = socketResults.get(i); |
| | | if (!deviceMsgModel.getDeviceMsgType().equals("shuttleInit")) { |
| | | continue; |
| | | } |
| | | if (!socketResult.get("msgType").equals("requestMsg")) {//不是请求内容 |
| | | continue; |
| | | } |
| | | removeIdx = i; |
| | | socketResult = JSON.parseObject(JSON.toJSONString(deviceMsgModel.getDeviceMsg())); |
| | | break; |
| | | } |
| | | |
| | | JSONObject resultResponse = JSON.parseObject(socketResult.get("request").toString()); |
| | | JSONObject resultHeader = JSON.parseObject(resultResponse.get("header").toString()); |
| | | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); |
| | | String requestType = resultBody.getString("requestType"); |
| | | Integer requestId = resultHeader.getInteger("requestId"); |
| | | if (requestType.equals("init")) { |
| | | removeIdx = i;//此数据已经处理,从结果集中剔除 |
| | | socketResults.remove(removeIdx); |
| | | if (socketResult == null) { |
| | | return; |
| | | } |
| | | |
| | | Integer code = resultBody.getInteger("code"); |
| | | //小车复位请求 |
| | | ShuttleCommand initCommand = getInitCommand(requestId, code); |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(initCommand.getBody(), NyShuttleHttpCommand.class); |
| | | JSONObject requestResult = requestCommand(httpCommand); |
| | | JSONObject resultResponse = JSON.parseObject(socketResult.get("request").toString()); |
| | | JSONObject resultHeader = JSON.parseObject(resultResponse.get("header").toString()); |
| | | JSONObject resultBody = JSON.parseObject(resultResponse.get("body").toString()); |
| | | String requestType = resultBody.getString("requestType"); |
| | | Integer requestId = resultHeader.getInteger("requestId"); |
| | | if (requestType.equals("init")) { |
| | | socketResults.remove(removeIdx); |
| | | |
| | | log.info(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); |
| | | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); |
| | | break; |
| | | } |
| | | Integer code = resultBody.getInteger("code"); |
| | | //小车复位请求 |
| | | ShuttleCommand initCommand = getInitCommand(requestId, code); |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(initCommand.getBody(), NyShuttleHttpCommand.class); |
| | | requestCommand(httpCommand); |
| | | |
| | | log.info(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); |
| | | OutputQueue.SHUTTLE.offer(MessageFormat.format("【{0}】四向车复位上报 ===>> [code:{1}] [ip:{2}] [port:{3}]", deviceConfig.getDeviceNo(), code, deviceConfig.getIp(), deviceConfig.getPort())); |
| | | } |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | |
| | | return response; |
| | | } |
| | | |
| | | // @Override |
| | | // public CommandResponse move(ShuttleCommand command) { |
| | | // CommandResponse response = new CommandResponse(false); |
| | | // try { |
| | | // //发出请求 |
| | | // NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); |
| | | // Map<String, Object> body = httpCommand.getRequest().getBody(); |
| | | // Object pathObj = body.get("path"); |
| | | // int taskId = Integer.parseInt(body.get("taskId").toString()); |
| | | // List<JSONObject> path = JSON.parseArray(JSON.toJSONString(pathObj), JSONObject.class); |
| | | // ArrayList<NyShuttleHttpCommand> commandList = new ArrayList<>(); |
| | | // while (!path.isEmpty()) { |
| | | // ArrayList<Map<String, Object>> list = new ArrayList<>(); |
| | | // if (path.size() > 10) { |
| | | // List<JSONObject> subList = path.subList(0, 10); |
| | | // list.addAll(subList); |
| | | // |
| | | // List<JSONObject> tmp = new ArrayList<>(); |
| | | // for (int i = 10; i < path.size(); i++) { |
| | | // tmp.add(path.get(i)); |
| | | // } |
| | | // path = tmp; |
| | | // }else { |
| | | // list.addAll(path); |
| | | // path.clear(); |
| | | // } |
| | | // |
| | | // NyShuttleHttpCommand httpCommandCopy = JSON.parseObject(JSON.toJSONString(httpCommand), NyShuttleHttpCommand.class); |
| | | // JSONObject bodyCopy = JSON.parseObject(JSON.toJSONString(body)); |
| | | // |
| | | // NyShuttleHttpCommand.NyRequest request = httpCommandCopy.getRequest(); |
| | | // bodyCopy.put("path", list); |
| | | // bodyCopy.put("taskId", taskId++); |
| | | // request.setBody(bodyCopy); |
| | | // httpCommandCopy.setRequest(request); |
| | | // |
| | | // commandList.add(httpCommandCopy);//add copy |
| | | // } |
| | | // |
| | | // for (NyShuttleHttpCommand requestCommand : commandList) { |
| | | // while (true) { |
| | | // JSONObject result = requestCommand(requestCommand); |
| | | // if (result == null) { |
| | | //// return response;//请求失败 |
| | | // continue;//请求失败尝试重新请求 |
| | | // } |
| | | // this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 |
| | | // response.setMessage(JSON.toJSONString(result)); |
| | | // response.setResult(true); |
| | | // break; |
| | | // } |
| | | // } |
| | | // return response; |
| | | // } catch (Exception e) { |
| | | // e.printStackTrace(); |
| | | // response.setMessage(e.getMessage()); |
| | | // return response; |
| | | // } |
| | | // } |
| | | |
| | | @Override |
| | | public CommandResponse move(ShuttleCommand command) { |
| | | CommandResponse response = new CommandResponse(false); |
| | | try { |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); |
| | | Map<String, Object> body = httpCommand.getRequest().getBody(); |
| | | Object pathObj = body.get("path"); |
| | | int taskId = Integer.parseInt(body.get("taskId").toString()); |
| | | List<JSONObject> path = JSON.parseArray(JSON.toJSONString(pathObj), JSONObject.class); |
| | | ArrayList<NyShuttleHttpCommand> commandList = new ArrayList<>(); |
| | | while (!path.isEmpty()) { |
| | | ArrayList<Map<String, Object>> list = new ArrayList<>(); |
| | | if (path.size() > 10) { |
| | | List<JSONObject> subList = path.subList(0, 10); |
| | | list.addAll(subList); |
| | | |
| | | List<JSONObject> tmp = new ArrayList<>(); |
| | | for (int i = 10; i < path.size(); i++) { |
| | | tmp.add(path.get(i)); |
| | | } |
| | | path = tmp; |
| | | }else { |
| | | list.addAll(path); |
| | | path.clear(); |
| | | } |
| | | |
| | | NyShuttleHttpCommand httpCommandCopy = JSON.parseObject(JSON.toJSONString(httpCommand), NyShuttleHttpCommand.class); |
| | | JSONObject bodyCopy = JSON.parseObject(JSON.toJSONString(body)); |
| | | |
| | | NyShuttleHttpCommand.NyRequest request = httpCommandCopy.getRequest(); |
| | | bodyCopy.put("path", list); |
| | | bodyCopy.put("taskId", taskId++); |
| | | request.setBody(bodyCopy); |
| | | httpCommandCopy.setRequest(request); |
| | | |
| | | commandList.add(httpCommandCopy);//add copy |
| | | String resultKey = requestCommand(httpCommand); |
| | | //查询请求结果 |
| | | JSONObject result = queryCommandStatus(resultKey); |
| | | if (result == null) { |
| | | return response;//请求失败 |
| | | } |
| | | |
| | | for (NyShuttleHttpCommand requestCommand : commandList) { |
| | | while (true) { |
| | | JSONObject result = requestCommand(requestCommand); |
| | | if (result == null) { |
| | | // return response;//请求失败 |
| | | continue;//请求失败尝试重新请求 |
| | | } |
| | | this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 |
| | | response.setMessage(JSON.toJSONString(result)); |
| | | response.setResult(true); |
| | | break; |
| | | } |
| | | } |
| | | this.shuttleProtocol.setSendTime(System.currentTimeMillis());//指令下发时间 |
| | | response.setMessage(JSON.toJSONString(result)); |
| | | response.setResult(true); |
| | | return response; |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | |
| | | try { |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); |
| | | JSONObject result = requestCommand(httpCommand); |
| | | String resultKey = requestCommand(httpCommand); |
| | | //查询请求结果 |
| | | JSONObject result = queryCommandStatus(resultKey); |
| | | if (result == null) { |
| | | return response;//请求失败 |
| | | } |
| | |
| | | try { |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); |
| | | JSONObject result = requestCommand(httpCommand); |
| | | String resultKey = requestCommand(httpCommand); |
| | | //查询请求结果 |
| | | JSONObject result = queryCommandStatus(resultKey); |
| | | if (result == null) { |
| | | return response;//请求失败 |
| | | } |
| | |
| | | try { |
| | | //发出请求 |
| | | NyShuttleHttpCommand httpCommand = JSON.parseObject(command.getBody(), NyShuttleHttpCommand.class); |
| | | JSONObject result = requestCommand(httpCommand); |
| | | String resultKey = requestCommand(httpCommand); |
| | | //查询请求结果 |
| | | JSONObject result = queryCommandStatus(resultKey); |
| | | if (result == null) { |
| | | return response;//请求失败 |
| | | } |
| | |
| | | return httpStandard; |
| | | } |
| | | |
| | | //发出请求-同步 |
| | | private JSONObject requestCommand(NyShuttleHttpCommand httpCommand) throws IOException { |
| | | //发出请求 |
| | | private String requestCommand(NyShuttleHttpCommand httpCommand) throws IOException { |
| | | try { |
| | | DeviceMsgUtils deviceMsgUtils = SpringUtils.getBean(DeviceMsgUtils.class); |
| | | if (deviceMsgUtils == null) { |
| | |
| | | commandMsgModel.setDeviceType(String.valueOf(SlaveType.Shuttle)); |
| | | commandMsgModel.setCommand(data); |
| | | String key = deviceMsgUtils.sendDeviceCommand(SlaveType.Shuttle, deviceConfig.getDeviceNo(), commandMsgModel); |
| | | |
| | | String requestType = null; |
| | | String taskId = null; |
| | | try { |
| | | requestType = httpCommand.getRequest().getBody().get("requestType").toString(); |
| | | taskId = httpCommand.getRequest().getBody().get("taskId").toString(); |
| | | } catch (Exception e) { |
| | | // return null; |
| | | //taskId可能取空,不报错,正常情况 |
| | | } |
| | | |
| | | // 获取服务器响应 |
| | | // 尝试30次 |
| | | JSONObject result = null; |
| | | for (int i = 0; i < 30; i++) { |
| | | result = getRequestBody(requestType, taskId); |
| | | if (result == null) { |
| | | try { |
| | | Thread.sleep(100); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | }else { |
| | | break; |
| | | } |
| | | } |
| | | return result;//返回Body结果集 |
| | | return key; |
| | | }catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | return null; |
| | | } |
| | | |
| | | //发出请求-移步 |
| | | private void requestCommandAsync(NyShuttleHttpCommand httpCommand) throws IOException { |
| | | try { |
| | | DeviceMsgUtils deviceMsgUtils = SpringUtils.getBean(DeviceMsgUtils.class); |
| | | if (deviceMsgUtils == null) { |
| | | return; |
| | | private JSONObject queryCommandStatus(String resultKey) { |
| | | // 获取服务器响应 |
| | | // 尝试50次 |
| | | JSONObject result = null; |
| | | for (int i = 0; i < 50; i++) { |
| | | result = getRequestBody(resultKey); |
| | | if (result == null) { |
| | | try { |
| | | Thread.sleep(500); |
| | | } catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | }else { |
| | | break; |
| | | } |
| | | |
| | | //压缩数据包 |
| | | JSONObject data = JSON.parseObject(JSON.toJSONString(httpCommand)); |
| | | data.remove("nodes"); |
| | | |
| | | DeviceCommandMsgModel commandMsgModel = new DeviceCommandMsgModel(); |
| | | commandMsgModel.setDeviceId(deviceConfig.getDeviceNo()); |
| | | commandMsgModel.setDeviceType(String.valueOf(SlaveType.Shuttle)); |
| | | commandMsgModel.setCommand(data); |
| | | String key = deviceMsgUtils.sendDeviceCommand(SlaveType.Shuttle, deviceConfig.getDeviceNo(), commandMsgModel); |
| | | |
| | | String requestType = null; |
| | | String taskId = null; |
| | | try { |
| | | requestType = httpCommand.getRequest().getBody().get("requestType").toString(); |
| | | taskId = httpCommand.getRequest().getBody().get("taskId").toString(); |
| | | } catch (Exception e) { |
| | | // return null; |
| | | //taskId可能取空,不报错,正常情况 |
| | | } |
| | | }catch (Exception e) { |
| | | e.printStackTrace(); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | private JSONObject filterBodyData(JSONObject data) { |