package com.dy.aceMw.server.rtuData.p206V1_0_0; import com.dy.aceMw.server.rtuData.TaskSurpport; import com.dy.aceMw.server.rtuData.dbSv.DbSv; import com.dy.common.mw.protocol.Data; import com.dy.common.springUtil.SpringContextUtil; import com.dy.common.util.DateTime; import com.dy.pipIrrGlobal.pojoPr.PrController; import com.dy.pipIrrGlobal.pojoPr.PrControllerTramp; import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.Logger; import java.text.DateFormat; import java.text.ParseException; import java.text.SimpleDateFormat; public class TkPreGenObjs extends TaskSurpport { private static final Logger log = LogManager.getLogger(TkPreGenObjs.class.getName()) ; //类ID,一定与Tree.xml配置文件中配置一致 public static final String taskId = "TkPreGenObjs" ; /** * 执行节点任务 * @param data 需要处理的数据 */ @Override public void execute(Object data) throws ParseException { DateFormat fmt =new SimpleDateFormat(("yyyy_MM_dd_HH_mm_ss")); Data d = (Data)data ; String rtuAddr = d.getRtuAddr() ;//TkRtuData里判断了rtuAddr为空 DbSv sv = (DbSv)SpringContextUtil.getBean(DbSv.class) ; if(sv != null){ PrController controller = sv.getPrControllerByRtuAddr(rtuAddr) ; if(controller == null){ //数据库中未查询到控制器(RTU实体) //流浪者控制器 PrControllerTramp rtuTramp = sv.getPrControllerTrampByRtuAddr(rtuAddr); if(rtuTramp == null){ rtuTramp = new PrControllerTramp(null, rtuAddr, d.getProtocol(), fmt.parse(DateTime.yyyy_MM_dd_HH_mm_ss())) ; this.taskResult = new Object[]{sv, null, rtuTramp} ; this.toNextOneTask(data, TkDealControllerTramp.taskId); } } //不论是否为流浪控制器(RTU实体),都要进行下步工作 this.taskResult = new Object[]{sv, controller, null} ; this.toNextTasks(data); }else{ log.error("严重错误,未能得到DbSv对象"); } } }