|  |  | 
 |  |  | import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; | 
 |  |  | import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory; | 
 |  |  | import com.dy.pipIrrGlobal.pojoSe.SeVirtualCard; | 
 |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedParam; | 
 |  |  | import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; | 
 |  |  | import com.dy.pipIrrGlobal.voSe.VoVirtualCard; | 
 |  |  | import com.dy.pipIrrRemote.common.CommandSv; | 
 |  |  | import com.dy.pipIrrRemote.common.dto.DtoBase; | 
 |  |  | import com.dy.pipIrrRemote.common.dto.ValveClose; | 
 |  |  | import com.dy.pipIrrRemote.common.dto.ValveOpen; | 
 |  |  | import com.dy.pipIrrRemote.common.enums.LastOperateENUM; | 
 |  |  | import com.dy.pipIrrRemote.result.RemoteResultCode; | 
 |  |  | import com.dy.pipIrrSell.virtualCard.enums.LastOperateENUM; | 
 |  |  | import io.swagger.v3.oas.annotations.tags.Tag; | 
 |  |  | import jakarta.validation.Valid; | 
 |  |  | import lombok.RequiredArgsConstructor; | 
 |  |  | 
 |  |  |     private String rtuResultSendWebUrl = "http://127.0.0.1:8081/remote/comRes/receive" ; | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 小程序远程开阀 | 
 |  |  |      * 平台远程开阀 | 
 |  |  |      * @param valve | 
 |  |  |      * @param bindingResult | 
 |  |  |      * @return | 
 |  |  | 
 |  |  |         if(!setuped) { | 
 |  |  |             setUp(); | 
 |  |  |         } | 
 |  |  | // 取水口ID换取水口对象 | 
 |  |  | // 如果取水口为打开状态,则不允许被开阀 | 
 |  |  |  | 
 |  |  |         // 虚拟卡ID换虚拟卡对象 | 
 |  |  |         VoVirtualCard vc = commandSv.getVcById(vcId); | 
 |  |  | 
 |  |  |                 // 回调失败 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     //rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     //rmCommandHistory.setId(comId); | 
 |  |  |                     //rmCommandHistory.setResult((byte)0); | 
 |  |  |                     //commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
 |  |  |                     //return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  | 
 |  |  |                  * 执行成功 | 
 |  |  |                  * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
 |  |  |                  */ | 
 |  |  |                 SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 virtualCard.setId(vcId); | 
 |  |  |                 virtualCard.setInUse((byte) 1); | 
 |  |  |                 virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |                 //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 //virtualCard.setId(vcId); | 
 |  |  |                 //virtualCard.setInUse((byte) 1); | 
 |  |  |                 //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                 // 回调返回的内容 | 
 |  |  |                 Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(myData) ; | 
 |  |  |                 //Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 //return BaseResponseUtils.buildSuccess(myData); | 
 |  |  |  | 
 |  |  |                 JSONObject job_response = new JSONObject(); | 
 |  |  |                 job_response.put("rtuAddr", rtuAddr); | 
 |  |  |                 job_response.put("vcNum", vc.getVcNum()); | 
 |  |  |                 job_response.put("orderNo", orderNo); | 
 |  |  |                 //job_response.put("operator", operator); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(job_response); | 
 |  |  |             } else { | 
 |  |  |                 // 请求失败 | 
 |  |  |                 JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
 |  |  | 
 |  |  |                 // 处理回调 | 
 |  |  |                 BaseResponse response_CallBack = dealWithCallBack(comId); | 
 |  |  |  | 
 |  |  |                 //回调失败 | 
 |  |  |                 //回调异常 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
 |  |  |                     //return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调超时 | 
 |  |  |                 if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
 |  |  |                     /** | 
 |  |  |                      * 回调超时,暂时认为执行失败 | 
 |  |  |                      * 命令置为失败 | 
 |  |  |                      * 虚拟卡依旧保持使用中的状态 | 
 |  |  |                      * 不返回关阀参数 | 
 |  |  |                      */ | 
 |  |  |  | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |  | 
 |  |  |                     //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                     //virtualCard.setId(vcId); | 
 |  |  |                     //virtualCard.setInUse((byte) 1); | 
 |  |  |                     //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                     //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                     //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                     //JSONObject job_response = new JSONObject(); | 
 |  |  |                     //job_response.put("message", RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
 |  |  |                     //job_response.put("rtuAddr", rtuAddr); | 
 |  |  |                     //job_response.put("vcNum", vc.getVcNum()); | 
 |  |  |                     //job_response.put("orderNo", orderNo); | 
 |  |  |                     //return BaseResponseUtils.buildSuccess(job_response); | 
 |  |  |                     return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
 |  |  |  | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调成功,再判断执行是否成功 | 
 |  |  | 
 |  |  |                 seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                 // 回调返回的内容 | 
 |  |  |                 Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(myData) ; | 
 |  |  |                 //Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 //return BaseResponseUtils.buildSuccess(myData) ; | 
 |  |  |  | 
 |  |  |                 JSONObject job_response = new JSONObject(); | 
 |  |  |                 job_response.put("message", "ok"); | 
 |  |  |                 job_response.put("rtuAddr", rtuAddr); | 
 |  |  |                 job_response.put("vcNum", vc.getVcNum()); | 
 |  |  |                 job_response.put("orderNo", orderNo); | 
 |  |  |                 //job_response.put("operator", operator); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(job_response); | 
 |  |  |  | 
 |  |  |             } else { | 
 |  |  |                 // 请求失败 | 
 |  |  |                 JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
 |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 小程序远程关阀 | 
 |  |  |      * 平台远程关阀_参数模式 | 
 |  |  |      * @param valve | 
 |  |  |      * @param bindingResult | 
 |  |  |      * @return | 
 |  |  | 
 |  |  |                 // 回调失败 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     //rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     //rmCommandHistory.setId(comId); | 
 |  |  |                     //rmCommandHistory.setResult((byte)0); | 
 |  |  |                     //commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
 |  |  |                     //return BaseResponseUtils.buildError(WechatResultCode.GET_RESULT_ERROR.getMessage()); | 
 |  |  |                 } | 
 |  |  | 
 |  |  |                  * 执行成功 | 
 |  |  |                  * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
 |  |  |                  */ | 
 |  |  |                 Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                 SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 virtualCard.setId(vcId); | 
 |  |  |                 virtualCard.setInUse((byte) 0); | 
 |  |  |                 virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |                 //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                 //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 //virtualCard.setId(vcId); | 
 |  |  |                 //virtualCard.setInUse((byte) 0); | 
 |  |  |                 //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                 // 回调返回的内容 | 
 |  |  |                 Data myData = (Data)response_CallBack.getContent(); | 
 |  |  | 
 |  |  |                 // 处理回调 | 
 |  |  |                 BaseResponse response_CallBack = dealWithCallBack(comId); | 
 |  |  |  | 
 |  |  |                 // 回调失败 | 
 |  |  |                 // 回调异常 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调超时 | 
 |  |  |                 if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
 |  |  |                     /** | 
 |  |  |                      * 回调超时,暂时认为执行失败 | 
 |  |  |                      * 命令置为失败 | 
 |  |  |                      * 虚拟卡依旧保持使用中的状态 | 
 |  |  |                      */ | 
 |  |  |  | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |  | 
 |  |  |                     //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                     //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                     //virtualCard.setId(vcId); | 
 |  |  |                     //virtualCard.setInUse((byte) 0); | 
 |  |  |                     //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                     //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                     //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |                     return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调成功,再判断执行是否成功 | 
 |  |  |                 JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
 |  |  |                 System.out.println(job_content); | 
 |  |  |                 JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
 |  |  |                 System.out.println(job_subData); | 
 |  |  |                 Boolean dealResult = job_subData.getBoolean("success"); | 
 |  |  |                 if(!dealResult) { | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 /** | 
 |  |  |                  * 执行成功 | 
 |  |  |                  * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
 |  |  |                  */ | 
 |  |  |                 Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                 SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 virtualCard.setId(vcId); | 
 |  |  |                 virtualCard.setInUse((byte) 0); | 
 |  |  |                 virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                 // 回调返回的内容 | 
 |  |  |                 Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(myData) ; | 
 |  |  |             } else { | 
 |  |  |                 // 请求失败 | 
 |  |  |                 JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
 |  |  |                 return BaseResponseUtils.buildFail(job_param.getString("message")); | 
 |  |  |             } | 
 |  |  |         } else { | 
 |  |  |             return BaseResponseUtils.buildFail("系统暂不支持该协议"); | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * 平台远程关阀_取水口模式 | 
 |  |  |      * @param dtoBase | 
 |  |  |      * @param bindingResult | 
 |  |  |      * @return | 
 |  |  |      */ | 
 |  |  |     @PostMapping(path = "close_intake", consumes = MediaType.APPLICATION_JSON_VALUE) | 
 |  |  |     @Transactional(rollbackFor = Exception.class) | 
 |  |  |     @SsoAop() | 
 |  |  |     public BaseResponse<Boolean> closeByIntake(@RequestBody @Valid DtoBase dtoBase, BindingResult bindingResult) { | 
 |  |  |         DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyMMddHHmmss"); | 
 |  |  |         if(bindingResult != null && bindingResult.hasErrors()){ | 
 |  |  |             return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         Long intakeId = dtoBase.getIntakeId(); | 
 |  |  |         Long operator = dtoBase.getOperator(); | 
 |  |  |  | 
 |  |  |         VoUnclosedParam voUnclosedParam = commandSv.getUncloseParam(intakeId); | 
 |  |  |         if(voUnclosedParam == null) { | 
 |  |  |             return BaseResponseUtils.buildSuccess(RemoteResultCode.VALVE_CLOSED.getMessage()); | 
 |  |  |         } | 
 |  |  |         String rtuAddr = voUnclosedParam.getRtuAddr(); | 
 |  |  |         String vcNum = voUnclosedParam.getVcNum(); | 
 |  |  |         String orderNo = voUnclosedParam.getOrderNo(); | 
 |  |  |         Long comId = idLongGenerator.generate(); | 
 |  |  |  | 
 |  |  |         // 获取系统参数 | 
 |  |  |         if(!setuped) { | 
 |  |  |             setUp(); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         // 阀控器地址换取水口ID和通讯协议 | 
 |  |  |         JSONObject job_rtu = getRtu(null, rtuAddr); | 
 |  |  |         if(job_rtu == null) { | 
 |  |  |             return BaseResponseUtils.buildError(RemoteResultCode.RTU_NOT_EXIST.getMessage()); | 
 |  |  |         } | 
 |  |  |         //Long intakeId = job_rtu.getLong("intakeId"); | 
 |  |  |         String protocol = job_rtu.getString("protocol"); | 
 |  |  |  | 
 |  |  |         String commandCode = null; | 
 |  |  |         if(protocol.equals("p206V202404")) { | 
 |  |  |             // 获取功能码 | 
 |  |  |             commandCode = CodeV202404.cd_93; | 
 |  |  |  | 
 |  |  |             // 创建视图 | 
 |  |  |             ComCd93_A3Vo param = new ComCd93_A3Vo(); | 
 |  |  |             param.controllerType = controllerType; | 
 |  |  |             param.projectNo = projectNo; | 
 |  |  |             param.icCardNo = vcNum; | 
 |  |  |             param.orderNo = orderNo; | 
 |  |  |  | 
 |  |  |             // 构造命令 | 
 |  |  |             Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
 |  |  |  | 
 |  |  |             // 发送命令 | 
 |  |  |             JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
 |  |  |             if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
 |  |  |                 // 请求成功 | 
 |  |  |  | 
 |  |  |                 // 创建命令日志对象并添加到数据库中 | 
 |  |  |                 String commandName = CodeV202404.getCodeName(commandCode); | 
 |  |  |                 RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
 |  |  |                 commandSv.insert(rmCommandHistory); | 
 |  |  |  | 
 |  |  |                 // 处理回调 | 
 |  |  |                 BaseResponse response_CallBack = dealWithCallBack(comId); | 
 |  |  |  | 
 |  |  |                 // 回调失败 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     //rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     //rmCommandHistory.setId(comId); | 
 |  |  |                     //rmCommandHistory.setResult((byte)0); | 
 |  |  |                     //commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getMsg()); | 
 |  |  |                     //return BaseResponseUtils.buildError(WechatResultCode.GET_RESULT_ERROR.getMessage()); | 
 |  |  |                 } | 
 |  |  | 
 |  |  |                  * 执行成功 | 
 |  |  |                  * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
 |  |  |                  */ | 
 |  |  |                 //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                 //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 //virtualCard.setId(vcId); | 
 |  |  |                 //virtualCard.setInUse((byte) 0); | 
 |  |  |                 //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                 //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                 //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |  | 
 |  |  |                 // 回调返回的内容 | 
 |  |  |                 Data myData = (Data)response_CallBack.getContent(); | 
 |  |  |                 return BaseResponseUtils.buildSuccess(myData) ; | 
 |  |  |             } else { | 
 |  |  |                 // 请求失败 | 
 |  |  |                 JSONObject job_param = response_SendCom.getJSONObject("content").getJSONObject("param"); | 
 |  |  |                 return BaseResponseUtils.buildFail(job_param.getString("message")); | 
 |  |  |             } | 
 |  |  |         } else if(protocol.equals("p206V1_0_1")) { | 
 |  |  |             // 获取功能码 | 
 |  |  |             commandCode = CodeV1_0_1.cd_93; | 
 |  |  |  | 
 |  |  |             // 创建视图 | 
 |  |  |             Com98Vo param = new Com98Vo() ; | 
 |  |  |             param.icCardNo = vcNum; | 
 |  |  |             param.orderNo = orderNo; | 
 |  |  |  | 
 |  |  |             // 构造命令 | 
 |  |  |             Command com = command(comId, commandCode, rtuAddr, protocol, rtuResultSendWebUrl, param); | 
 |  |  |  | 
 |  |  |             // 发送命令 | 
 |  |  |             JSONObject response_SendCom= (JSONObject) JSON.toJSON(sendCom2Mw(com)); | 
 |  |  |             if(response_SendCom != null && response_SendCom.getString("code").equals("0001")) { | 
 |  |  |                 //if(1 > 0) { | 
 |  |  |                 // 请求成功 | 
 |  |  |  | 
 |  |  |                 // 创建命令日志对象并添加到数据库中 | 
 |  |  |                 String commandName = CodeV1_0_1.getCodeName(commandCode); | 
 |  |  |                 RmCommandHistory rmCommandHistory = getComHistory(comId, commandCode, commandName, intakeId, rtuAddr, protocol, param, operator); | 
 |  |  |                 commandSv.insert(rmCommandHistory); | 
 |  |  |  | 
 |  |  |                 // 处理回调 | 
 |  |  |                 BaseResponse response_CallBack = dealWithCallBack(comId); | 
 |  |  |  | 
 |  |  |                 // 回调异常 | 
 |  |  |                 if(!response_CallBack.getCode().equals("0001")) { | 
 |  |  |                     // 命令日志执行结果改为失败 | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调超时 | 
 |  |  |                 if(response_CallBack.getContent().toString().equals(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage())) { | 
 |  |  |                     /** | 
 |  |  |                      * 回调超时,暂时认为执行失败 | 
 |  |  |                      * 命令置为失败 | 
 |  |  |                      * 虚拟卡依旧保持使用中的状态 | 
 |  |  |                      */ | 
 |  |  |  | 
 |  |  |                     rmCommandHistory = new RmCommandHistory(); | 
 |  |  |                     rmCommandHistory.setId(comId); | 
 |  |  |                     rmCommandHistory.setResult((byte)0); | 
 |  |  |                     commandSv.updateCommandResult(rmCommandHistory); | 
 |  |  |  | 
 |  |  |                     //Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                     //SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                     //virtualCard.setId(vcId); | 
 |  |  |                     //virtualCard.setInUse((byte) 0); | 
 |  |  |                     //virtualCard.setLastOperate(LastOperateENUM.OPEN_VALVE.getCode()); | 
 |  |  |                     //virtualCard.setLastOperateTime(new Date()); | 
 |  |  |                     //seVirtualCardMapper.updateByPrimaryKeySelective(virtualCard); | 
 |  |  |                     return BaseResponseUtils.buildFail(RemoteResultCode.GET_RESULT_IN_ONE_MINUTE.getMessage()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 // 回调成功,再判断执行是否成功 | 
 |  |  |                 JSONObject job_content = (JSONObject)JSON.toJSON(response_CallBack.getContent()); | 
 |  |  |                 System.out.println(job_content); | 
 |  |  |                 JSONObject job_subData = (JSONObject) job_content.getJSONObject("subData").getJSONObject("subData"); | 
 |  |  |                 System.out.println(job_subData); | 
 |  |  |                 Boolean dealResult = job_subData.getBoolean("success"); | 
 |  |  |                 if(!dealResult) { | 
 |  |  |                     return BaseResponseUtils.buildFail(response_CallBack.getContent().toString()); | 
 |  |  |                 } | 
 |  |  |  | 
 |  |  |                 /** | 
 |  |  |                  * 执行成功 | 
 |  |  |                  * 更改虚拟卡状态:是否使用中、最后操作、最后操作时间 | 
 |  |  |                  */ | 
 |  |  |                 Long vcId = seVirtualCardMapper.getVcIdByNum(vcNum); | 
 |  |  |                 SeVirtualCard virtualCard = new SeVirtualCard(); | 
 |  |  |                 virtualCard.setId(vcId); |