panlinlin
2021-05-08 e48fa711a3664bece9b3e58840a75fe7c05bc47c
src/main/java/com/genersoft/iot/vmp/gb28181/transmit/request/impl/RegisterRequestProcessor.java
@@ -16,6 +16,10 @@
import javax.sip.message.Request;
import javax.sip.message.Response;
import com.genersoft.iot.vmp.gb28181.bean.WvpSipDate;
import gov.nist.javax.sip.RequestEventExt;
import gov.nist.javax.sip.header.SIPDateHeader;
import gov.nist.javax.sip.message.SIPRequest;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.StringUtils;
@@ -25,7 +29,6 @@
import com.genersoft.iot.vmp.gb28181.auth.DigestServerAuthenticationHelper;
import com.genersoft.iot.vmp.gb28181.auth.RegisterLogicHandler;
import com.genersoft.iot.vmp.gb28181.bean.Device;
import com.genersoft.iot.vmp.gb28181.bean.Host;
import com.genersoft.iot.vmp.gb28181.event.EventPublisher;
import com.genersoft.iot.vmp.gb28181.transmit.request.SIPRequestAbstractProcessor;
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
@@ -58,7 +61,9 @@
   @Override
   public void process(RequestEvent evt) {
      try {
         logger.info("收到注册请求,开始处理");
         RequestEventExt evtExt = (RequestEventExt)evt;
         String requestAddress = evtExt.getRemoteIpAddress() + ":" + evtExt.getRemotePort();
         logger.info("[{}] 收到注册请求,开始处理", requestAddress);
         Request request = evt.getRequest();
         Response response = null; 
@@ -77,9 +82,9 @@
         if (authorhead == null || !passwordCorrect) {
            
            if (authorhead == null) {
               logger.info("未携带授权头 回复401");
               logger.info("[{}] 未携带授权头 回复401", requestAddress);
            } else if (!passwordCorrect) {
               logger.info("密码错误 回复401");
               logger.info("[{}] 密码错误 回复401", requestAddress);
            }
            response = getMessageFactory().createResponse(Response.UNAUTHORIZED, request);
            new DigestServerAuthenticationHelper().generateChallenge(getHeaderFactory(), response, sipConfig.getSipDomain());
@@ -88,19 +93,23 @@
         else if (passwordCorrect) {
            response = getMessageFactory().createResponse(Response.OK, request);
            // 添加date头
            response.addHeader(getHeaderFactory().createDateHeader(Calendar.getInstance(Locale.ENGLISH)));
            SIPDateHeader dateHeader = new SIPDateHeader();
            // 使用自己修改的
            WvpSipDate wvpSipDate = new WvpSipDate(Calendar.getInstance(Locale.ENGLISH).getTimeInMillis());
            dateHeader.setDate(wvpSipDate);
            response.addHeader(dateHeader);
            ExpiresHeader expiresHeader = (ExpiresHeader) request.getHeader(Expires.NAME);
            // 添加Contact头
            response.addHeader(request.getHeader(ContactHeader.NAME));
            // 添加Expires头
            response.addHeader(request.getExpires());
            
            // 1.获取到通信地址等信息,保存到Redis
            // 获取到通信地址等信息
            FromHeader fromHeader = (FromHeader) request.getHeader(FromHeader.NAME);
            ViaHeader viaHeader = (ViaHeader) request.getHeader(ViaHeader.NAME);
            String received = viaHeader.getReceived();
            int rPort = viaHeader.getRPort();
            // 本地模拟设备 received 为空 rPort 为 -1
            // 解析本地地址替代
            if (StringUtils.isEmpty(received) || rPort == -1) {
               received = viaHeader.getHost();
@@ -110,9 +119,12 @@
            AddressImpl address = (AddressImpl) fromHeader.getAddress();
            SipUri uri = (SipUri) address.getURI();
            String deviceId = uri.getUser();
            device = new Device();
            device.setStreamMode("UDP");
            device.setDeviceId(deviceId);
            device = storager.queryVideoDevice(deviceId);
            if (device == null) {
               device = new Device();
               device.setStreamMode("UDP");
               device.setDeviceId(deviceId);
            }
            device.setIp(received);
            device.setPort(rPort);
            device.setHostAddress(received.concat(":").concat(String.valueOf(rPort)));
@@ -137,19 +149,16 @@
         // 注册成功
         // 保存到redis
         // 下发catelog查询目录
         if (registerFlag == 1 && device != null) {
            logger.info("注册成功! deviceId:" + device.getDeviceId());
            boolean exists = storager.exists(device.getDeviceId());
         if (registerFlag == 1 ) {
            logger.info("[{}] 注册成功! deviceId:" + device.getDeviceId(), requestAddress);
            device.setRegisterTimeMillis(System.currentTimeMillis());
            storager.updateDevice(device);
            publisher.onlineEventPublish(device.getDeviceId(), VideoManagerConstants.EVENT_ONLINE_REGISTER);
            // 只有第一次注册才更新通道
            if (!exists) {
               handler.onRegister(device);
            }
            // 重新注册更新设备和通道,以免设备替换或更新后信息无法更新
            handler.onRegister(device);
         } else if (registerFlag == 2) {
            logger.info("注销成功! deviceId:" + device.getDeviceId());
            logger.info("[{}] 注销成功! deviceId:" + device.getDeviceId(), requestAddress);
            publisher.outlineEventPublish(device.getDeviceId(), VideoManagerConstants.EVENT_OUTLINE_UNREGISTER);
         }
      } catch (SipException | InvalidArgumentException | NoSuchAlgorithmException | ParseException e) {