package com.ld.igds.protocol.fzzy.server;
|
|
import com.alibaba.fastjson.JSON;
|
import com.ld.igds.util.ContextUtil;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import com.ld.igds.protocol.fzzy.ServerUtils;
|
import com.ld.igds.protocol.fzzy.analysis.AnalysisService;
|
import com.ld.igds.protocol.fzzy.dto.ReMessage;
|
import com.ld.igds.util.SpringUtil;
|
import com.ld.io.api.IoMsgConsumer;
|
import com.ld.io.api.IoSession;
|
|
import org.apache.commons.lang3.StringUtils;
|
|
/**
|
* 接收终端返回回来的信息。
|
*
|
* @author Andy
|
*/
|
@Slf4j
|
public class MsgConsumer implements IoMsgConsumer {
|
|
private AnalysisService analysisService;
|
|
private static final String CHARSET = "UTF-8";
|
|
@Override
|
public void consume(IoSession session, byte[] bytes) {
|
ReMessage reMessage = null;
|
try {
|
String message = new String(bytes, CHARSET);
|
|
message = message.substring(ServerUtils.MSG_BEGIN.length());
|
|
reMessage = JSON.parseObject(message, ReMessage.class);
|
|
|
if (StringUtils.isEmpty(reMessage.getSn()) ||
|
StringUtils.isEmpty(reMessage.getIedId()) ||
|
StringUtils.isEmpty(reMessage.getFunctionId())) {
|
log.error("控制柜------>>>>平台:报文信息不完整,不做解析-IP={},port={},msg={}", session.getAddress(), session.getPort(), message);
|
return;
|
}
|
|
//根据SN获取组织编码
|
String companyId = ContextUtil.getCompanyIdBySn(reMessage.getSn());
|
if (null == companyId) {
|
log.error("控制柜------>>>>平台:报文信息不完整,当前分机系统未注册,不做解析-IP={},port={},msg={}", session.getAddress(), session.getPort(), message);
|
return;
|
}
|
|
reMessage.setCompanyId(companyId);
|
reMessage.setIp(session.getAddress());
|
reMessage.setPort(session.getPort());
|
reMessage.setStrMsg(message);
|
session.setCompanyId(companyId);
|
|
log.info("控制柜------>>>>平台:IP={},PORT={},message={}", reMessage.getIp(), reMessage.getPort(), message);
|
|
} catch (Exception e) {
|
log.error("控制柜------>>>>平台:收到报文解析异常:{}" , e.getMessage());
|
e.printStackTrace();
|
}
|
|
//调用解析接口开始解析
|
if (null == analysisService) {
|
analysisService = (AnalysisService) SpringUtil.getBean(AnalysisService.BEAN_ID);
|
}
|
analysisService.analysis(reMessage);
|
}
|
|
}
|