Conflicts:
	src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
pull/1/head
swwheihei 2020-07-16 16:09:48 +08:00
commit 29710b7cc1
49 changed files with 461 additions and 343 deletions

21
LICENSE Normal file
View File

@ -0,0 +1,21 @@
MIT License
Copyright (c) 2020 swwhaha
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.

View File

@ -39,7 +39,7 @@
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-undertow</artifactId> <artifactId>spring-boot-starter-tomcat</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.springframework.boot</groupId> <groupId>org.springframework.boot</groupId>
@ -127,7 +127,7 @@
<dependency> <dependency>
<groupId>org.dom4j</groupId> <groupId>org.dom4j</groupId>
<artifactId>dom4j</artifactId> <artifactId>dom4j</artifactId>
<version>2.1.1</version> <version>2.1.3</version>
</dependency> </dependency>
<dependency> <dependency>
<groupId>com.google.code.gson</groupId> <groupId>com.google.code.gson</groupId>

View File

@ -2,7 +2,7 @@ package com.genersoft.iot.vmp.common;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 2019530 3:04:04 * @date: 2019530 3:04:04
* *
*/ */

View File

@ -13,7 +13,7 @@ import com.genersoft.iot.vmp.utils.redis.FastJsonRedisSerializer;
/** /**
* @Description:Redis使spring-data-redisapplication.ymlredis * @Description:Redis使spring-data-redisapplication.ymlredis
* @author: swwheihei * @author: songww
* @date: 2019530 10:58:25 * @date: 2019530 10:58:25
* *
*/ */

View File

@ -5,7 +5,7 @@ import org.springframework.context.annotation.Configuration;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202056 2:46:00 * @date: 202056 2:46:00
*/ */
@Configuration("vmConfig") @Configuration("vmConfig")

View File

@ -1,5 +1,6 @@
package com.genersoft.iot.vmp.gb28181; package com.genersoft.iot.vmp.gb28181;
import java.text.ParseException;
import java.util.Properties; import java.util.Properties;
import javax.annotation.PostConstruct; import javax.annotation.PostConstruct;
@ -84,7 +85,7 @@ public class SipLayer implements SipListener, Runnable {
* 0; public static final int TRACE_MESSAGES = 16; public static final int * 0; public static final int TRACE_MESSAGES = 16; public static final int
* TRACE_EXCEPTION = 17; public static final int TRACE_DEBUG = 32; * TRACE_EXCEPTION = 17; public static final int TRACE_DEBUG = 32;
*/ */
properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "0"); properties.setProperty("gov.nist.javax.sip.TRACE_LEVEL", "32");
properties.setProperty("gov.nist.javax.sip.SERVER_LOG", "sip_server_log"); properties.setProperty("gov.nist.javax.sip.SERVER_LOG", "sip_server_log");
properties.setProperty("gov.nist.javax.sip.DEBUG_LOG", "sip_debug_log"); properties.setProperty("gov.nist.javax.sip.DEBUG_LOG", "sip_debug_log");
sipStack = (SipStackImpl) sipFactory.createSipStack(properties); sipStack = (SipStackImpl) sipFactory.createSipStack(properties);
@ -99,13 +100,15 @@ public class SipLayer implements SipListener, Runnable {
} }
private void startTcpListener() throws Exception { private void startTcpListener() throws Exception {
ListeningPoint tcpListeningPoint = sipStack.createListeningPoint(sipConfig.getSipIp(), sipConfig.getSipPort(), "TCP"); ListeningPoint tcpListeningPoint = sipStack.createListeningPoint(sipConfig.getSipIp(), sipConfig.getSipPort(),
"TCP");
tcpSipProvider = sipStack.createSipProvider(tcpListeningPoint); tcpSipProvider = sipStack.createSipProvider(tcpListeningPoint);
tcpSipProvider.addSipListener(this); tcpSipProvider.addSipListener(this);
} }
private void startUdpListener() throws Exception { private void startUdpListener() throws Exception {
ListeningPoint udpListeningPoint = sipStack.createListeningPoint(sipConfig.getSipIp(), sipConfig.getSipPort(), "UDP"); ListeningPoint udpListeningPoint = sipStack.createListeningPoint(sipConfig.getSipIp(), sipConfig.getSipPort(),
"UDP");
udpSipProvider = sipStack.createSipProvider(udpListeningPoint); udpSipProvider = sipStack.createSipProvider(udpListeningPoint);
udpSipProvider.addSipListener(this); udpSipProvider.addSipListener(this);
} }
@ -126,14 +129,23 @@ public class SipLayer implements SipListener, Runnable {
int status = response.getStatusCode(); int status = response.getStatusCode();
if ((status >= 200) && (status < 300)) { // Success! if ((status >= 200) && (status < 300)) { // Success!
ISIPResponseProcessor processor = processorFactory.createResponseProcessor(evt); ISIPResponseProcessor processor = processorFactory.createResponseProcessor(evt);
try {
processor.process(evt, this, sipConfig); processor.process(evt, this, sipConfig);
} catch (ParseException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
// } else if (status == Response.TRYING) {
// trying不会回复
} else if ((status >= 100) && (status < 200)) {
// 增加其它无需回复的响应如101、180等
} else { } else {
logger.warn("接收到失败的response响应status" + status + ",message:" + response.getContent().toString()); logger.warn("接收到失败的response响应status" + status + ",message:" + response.getReasonPhrase()/* .getContent().toString()*/);
} }
// trying不会回复 // trying不会回复
if (status == Response.TRYING) { // if (status == Response.TRYING) {
} // }
} }
/** /**

View File

@ -8,7 +8,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202058 9:41:46 * @date: 202058 9:41:46
*/ */
@Component @Component

View File

@ -4,7 +4,7 @@ import java.util.List;
/** /**
* @Description:bean * @Description:bean
* @author: swwheihei * @author: songww
* @date: 202058 2:05:56 * @date: 202058 2:05:56
*/ */
public class RecordInfo { public class RecordInfo {

View File

@ -2,7 +2,7 @@ package com.genersoft.iot.vmp.gb28181.bean;
/** /**
* @Description:bean * @Description:bean
* @author: swwheihei * @author: songww
* @date: 202058 2:06:54 * @date: 202058 2:06:54
*/ */
public class RecordItem { public class RecordItem {

View File

@ -8,7 +8,7 @@ import com.genersoft.iot.vmp.utils.redis.RedisUtil;
/** /**
* @Description:线 * @Description:线
* @author: swwheihei * @author: songww
* @date: 2020513 2:40:29 * @date: 2020513 2:40:29
*/ */
@Component @Component

View File

@ -9,7 +9,7 @@ import com.genersoft.iot.vmp.gb28181.event.online.OnlineEvent;
/** /**
* @Description:Event线线 * @Description:Event线线
* @author: swwheihei * @author: songww
* @date: 202056 11:30:50 * @date: 202056 11:30:50
*/ */
@Component @Component

View File

@ -11,7 +11,7 @@ import com.genersoft.iot.vmp.gb28181.event.EventPublisher;
/** /**
* @Description:,redis线 * @Description:,redis线
* @author: swwheihei * @author: songww
* @date: 202056 11:35:46 * @date: 202056 11:35:46
*/ */
@Component @Component

View File

@ -4,7 +4,7 @@ import org.springframework.context.ApplicationEvent;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202056 11:33:13 * @date: 202056 11:33:13
*/ */
public class OfflineEvent extends ApplicationEvent { public class OfflineEvent extends ApplicationEvent {

View File

@ -14,7 +14,7 @@ import com.genersoft.iot.vmp.utils.redis.RedisUtil;
* @Description: 线线线 线 * @Description: 线线线 线
* 1{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor} * 1{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor}
* 2线,{@link com.genersoft.iot.vmp.gb28181.event.offline.OfflineEventListener} * 2线,{@link com.genersoft.iot.vmp.gb28181.event.offline.OfflineEventListener}
* @author: swwheihei * @author: songww
* @date: 202056 1:51:23 * @date: 202056 1:51:23
*/ */
@Component @Component

View File

@ -4,7 +4,7 @@ import org.springframework.context.ApplicationEvent;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202056 11:32:56 * @date: 202056 11:32:56
*/ */
public class OnlineEvent extends ApplicationEvent { public class OnlineEvent extends ApplicationEvent {

View File

@ -14,7 +14,7 @@ import com.genersoft.iot.vmp.utils.redis.RedisUtil;
* @Description: 线线线 线 * @Description: 线线线 线
* 1{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor} * 1{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.RegisterRequestProcessor}
* 2线,{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.MessageRequestProcessor} * 2线,{@link com.genersoft.iot.vmp.gb28181.transmit.request.impl.MessageRequestProcessor}
* @author: swwheihei * @author: songww
* @date: 202056 1:51:23 * @date: 202056 1:51:23
*/ */
@Component @Component

View File

@ -9,7 +9,7 @@ import com.genersoft.iot.vmp.utils.SpringBeanFactory;
/** /**
* @Description:SIPSSRCSSRC1001ID4844 * @Description:SIPSSRCSSRC1001ID4844
* @author: swwheihei * @author: songww
* @date: 2020510 11:57:57 * @date: 2020510 11:57:57
*/ */
public class SsrcUtil { public class SsrcUtil {

View File

@ -8,7 +8,7 @@ import org.springframework.stereotype.Component;
/** /**
* @Description:session * @Description:session
* @author: swwheihei * @author: songww
* @date: 2020513 4:03:02 * @date: 2020513 4:03:02
*/ */
@Component @Component

View File

@ -26,7 +26,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.response.impl.OtherResponseProcess
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202053 4:24:37 * @date: 202053 4:24:37
*/ */
@Component @Component

View File

@ -10,7 +10,7 @@ import org.springframework.web.context.request.async.DeferredResult;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202058 7:59:05 * @date: 202058 7:59:05
*/ */
@Component @Component

View File

@ -2,7 +2,7 @@ package com.genersoft.iot.vmp.gb28181.transmit.callback;
/** /**
* @Description:TODO() * @Description:TODO()
* @author: swwheihei * @author: songww
* @date: 202058 1:09:18 * @date: 202058 1:09:18
*/ */
public class RequestMessage { public class RequestMessage {

View File

@ -4,7 +4,7 @@ import com.genersoft.iot.vmp.gb28181.bean.Device;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202053 9:16:34 * @date: 202053 9:16:34
*/ */
public interface ISIPCommander { public interface ISIPCommander {

View File

@ -25,7 +25,7 @@ import com.genersoft.iot.vmp.gb28181.bean.Host;
/** /**
* @Description:request TODO * @Description:request TODO
* @author: swwheihei * @author: songww
* @date: 202056 9:29:02 * @date: 202056 9:29:02
*/ */
@Component @Component
@ -79,7 +79,8 @@ public class SIPRequestHeaderProvider {
SipURI requestLine = layer.getAddressFactory().createSipURI(channelId, host.getAddress()); SipURI requestLine = layer.getAddressFactory().createSipURI(channelId, host.getAddress());
//via //via
ArrayList<ViaHeader> viaHeaders = new ArrayList<ViaHeader>(); ArrayList<ViaHeader> viaHeaders = new ArrayList<ViaHeader>();
ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(sipConfig.getSipIp(), sipConfig.getSipPort(), device.getTransport(), viaTag); // ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(sipConfig.getSipIp(), sipConfig.getSipPort(), device.getTransport(), viaTag);
ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(device.getHost().getIp(), device.getHost().getPort(), device.getTransport(), viaTag);
viaHeader.setRPort(); viaHeader.setRPort();
viaHeaders.add(viaHeader); viaHeaders.add(viaHeader);
//from //from
@ -108,6 +109,7 @@ public class SIPRequestHeaderProvider {
request = layer.getMessageFactory().createRequest(requestLine, Request.INVITE, callIdHeader, cSeqHeader,fromHeader, toHeader, viaHeaders, maxForwards); request = layer.getMessageFactory().createRequest(requestLine, Request.INVITE, callIdHeader, cSeqHeader,fromHeader, toHeader, viaHeaders, maxForwards);
Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), sipConfig.getSipIp()+":"+sipConfig.getSipPort())); Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), sipConfig.getSipIp()+":"+sipConfig.getSipPort()));
// Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), device.getHost().getIp()+":"+device.getHost().getPort()));
request.addHeader(layer.getHeaderFactory().createContactHeader(concatAddress)); request.addHeader(layer.getHeaderFactory().createContactHeader(concatAddress));
ContentTypeHeader contentTypeHeader = layer.getHeaderFactory().createContentTypeHeader("Application", "SDP"); ContentTypeHeader contentTypeHeader = layer.getHeaderFactory().createContentTypeHeader("Application", "SDP");
@ -122,7 +124,8 @@ public class SIPRequestHeaderProvider {
SipURI requestLine = layer.getAddressFactory().createSipURI(device.getDeviceId(), host.getAddress()); SipURI requestLine = layer.getAddressFactory().createSipURI(device.getDeviceId(), host.getAddress());
//via //via
ArrayList<ViaHeader> viaHeaders = new ArrayList<ViaHeader>(); ArrayList<ViaHeader> viaHeaders = new ArrayList<ViaHeader>();
ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(sipConfig.getSipIp(), sipConfig.getSipPort(), device.getTransport(), viaTag); // ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(sipConfig.getSipIp(), sipConfig.getSipPort(), device.getTransport(), viaTag);
ViaHeader viaHeader = layer.getHeaderFactory().createViaHeader(device.getHost().getIp(), device.getHost().getPort(), device.getTransport(), viaTag);
viaHeader.setRPort(); viaHeader.setRPort();
viaHeaders.add(viaHeader); viaHeaders.add(viaHeader);
//from //from
@ -151,6 +154,7 @@ public class SIPRequestHeaderProvider {
request = layer.getMessageFactory().createRequest(requestLine, Request.INVITE, callIdHeader, cSeqHeader,fromHeader, toHeader, viaHeaders, maxForwards); request = layer.getMessageFactory().createRequest(requestLine, Request.INVITE, callIdHeader, cSeqHeader,fromHeader, toHeader, viaHeaders, maxForwards);
Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), sipConfig.getSipIp()+":"+sipConfig.getSipPort())); Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), sipConfig.getSipIp()+":"+sipConfig.getSipPort()));
// Address concatAddress = layer.getAddressFactory().createAddress(layer.getAddressFactory().createSipURI(sipConfig.getSipId(), device.getHost().getIp()+":"+device.getHost().getPort()));
request.addHeader(layer.getHeaderFactory().createContactHeader(concatAddress)); request.addHeader(layer.getHeaderFactory().createContactHeader(concatAddress));
ContentTypeHeader contentTypeHeader = layer.getHeaderFactory().createContentTypeHeader("Application", "SDP"); ContentTypeHeader contentTypeHeader = layer.getHeaderFactory().createContentTypeHeader("Application", "SDP");

View File

@ -7,10 +7,13 @@ import javax.sip.Dialog;
import javax.sip.InvalidArgumentException; import javax.sip.InvalidArgumentException;
import javax.sip.SipException; import javax.sip.SipException;
import javax.sip.TransactionDoesNotExistException; import javax.sip.TransactionDoesNotExistException;
import javax.sip.address.Address;
import javax.sip.address.SipURI;
import javax.sip.header.ViaHeader; import javax.sip.header.ViaHeader;
import javax.sip.message.Request; import javax.sip.message.Request;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.security.SecurityProperties.Headers;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import com.genersoft.iot.vmp.conf.SipConfig; import com.genersoft.iot.vmp.conf.SipConfig;
@ -21,9 +24,12 @@ import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommander;
import com.genersoft.iot.vmp.gb28181.transmit.cmd.SIPRequestHeaderProvider; import com.genersoft.iot.vmp.gb28181.transmit.cmd.SIPRequestHeaderProvider;
import com.genersoft.iot.vmp.gb28181.utils.DateUtil; import com.genersoft.iot.vmp.gb28181.utils.DateUtil;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202053 9:22:48 * @date: 202053 9:22:48
*/ */
@Component @Component
@ -94,6 +100,49 @@ public class SIPCommander implements ISIPCommander {
return ptzCmd(device, channelId, 0, 0, inOut, 0, zoomSpeed); return ptzCmd(device, channelId, 0, 0, inOut, 0, zoomSpeed);
} }
/**
*
*
* @param leftRight 0: 1: 2:
* @param upDown 0: 1: 2:
* @param inOut 0: 1: 2:
* @param moveSpeed 0XFF (0-255)
* @param zoomSpeed 0X1 (0-255)
*/
public static String cmdString(int leftRight, int upDown, int inOut, int moveSpeed, int zoomSpeed) {
int cmdCode = 0;
if (leftRight == 2) {
cmdCode|=0x01; // 右移
} else if(leftRight == 1) {
cmdCode|=0x02; // 左移
}
if (upDown == 2) {
cmdCode|=0x04; // 下移
} else if(upDown == 1) {
cmdCode|=0x08; // 上移
}
if (inOut == 2) {
cmdCode |= 0x10; // 放大
} else if(inOut == 1) {
cmdCode |= 0x20; // 缩小
}
StringBuilder builder = new StringBuilder("A50F01");
String strTmp;
strTmp = String.format("%02X", cmdCode);
builder.append(strTmp, 0, 2);
strTmp = String.format("%02X", moveSpeed);
builder.append(strTmp, 0, 2);
builder.append(strTmp, 0, 2);
strTmp = String.format("%X", zoomSpeed);
builder.append(strTmp, 0, 1).append("0");
//计算校验码
int checkCode = (0XA5 + 0X0F + 0X01 + cmdCode + moveSpeed + moveSpeed + (zoomSpeed /*<< 4*/ & 0XF0)) % 0X100;
strTmp = String.format("%02X", checkCode);
builder.append(strTmp, 0, 2);
return builder.toString();
}
/** /**
* *
* *
@ -109,13 +158,14 @@ public class SIPCommander implements ISIPCommander {
public boolean ptzCmd(Device device, String channelId, int leftRight, int upDown, int inOut, int moveSpeed, public boolean ptzCmd(Device device, String channelId, int leftRight, int upDown, int inOut, int moveSpeed,
int zoomSpeed) { int zoomSpeed) {
try { try {
String cmdStr= cmdString(leftRight, upDown, inOut, moveSpeed, zoomSpeed);
StringBuffer ptzXml = new StringBuffer(200); StringBuffer ptzXml = new StringBuffer(200);
ptzXml.append("<?xml version=\"1.0\" ?>"); ptzXml.append("<?xml version=\"1.0\" ?>");
ptzXml.append("<Control>"); ptzXml.append("<Control>");
ptzXml.append("<CmdType>DeviceControl</CmdType>"); ptzXml.append("<CmdType>DeviceControl</CmdType>");
ptzXml.append("<SN>" + (int)((Math.random()*9+1)*100000) + "</SN>"); ptzXml.append("<SN>" + (int)((Math.random()*9+1)*100000) + "</SN>");
ptzXml.append("<DeviceID>" + channelId + "</DeviceID>"); ptzXml.append("<DeviceID>" + channelId + "</DeviceID>");
ptzXml.append("<PTZCmd>" + "</PTZCmd>"); ptzXml.append("<PTZCmd>" + cmdStr + "</PTZCmd>");
ptzXml.append("<Info>"); ptzXml.append("<Info>");
ptzXml.append("</Info>"); ptzXml.append("</Info>");
ptzXml.append("</Control>"); ptzXml.append("</Control>");
@ -123,7 +173,6 @@ public class SIPCommander implements ISIPCommander {
Request request = headerProvider.createMessageRequest(device, ptzXml.toString(), "ViaPtzBranch", "FromPtzTag", "ToPtzTag"); Request request = headerProvider.createMessageRequest(device, ptzXml.toString(), "ViaPtzBranch", "FromPtzTag", "ToPtzTag");
transmitRequest(device, request); transmitRequest(device, request);
return true; return true;
} catch (SipException | ParseException | InvalidArgumentException e) { } catch (SipException | ParseException | InvalidArgumentException e) {
e.printStackTrace(); e.printStackTrace();
@ -245,6 +294,13 @@ public class SIPCommander implements ISIPCommander {
return; return;
} }
Request byeRequest = dialog.createRequest(Request.BYE); Request byeRequest = dialog.createRequest(Request.BYE);
SipURI byeURI = (SipURI) byeRequest.getRequestURI();
String vh = transaction.getRequest().getHeader(ViaHeader.NAME).toString();
Pattern p = Pattern.compile("(\\d+\\.\\d+\\.\\d+\\.\\d+)\\:(\\d+)");
Matcher matcher = p.matcher(vh);
if (matcher.find()) {
byeURI.setHost(matcher.group(1));
}
ViaHeader viaHeader = (ViaHeader) byeRequest.getHeader(ViaHeader.NAME); ViaHeader viaHeader = (ViaHeader) byeRequest.getHeader(ViaHeader.NAME);
String protocol = viaHeader.getTransport().toUpperCase(); String protocol = viaHeader.getTransport().toUpperCase();
ClientTransaction clientTransaction = null; ClientTransaction clientTransaction = null;
@ -258,6 +314,8 @@ public class SIPCommander implements ISIPCommander {
e.printStackTrace(); e.printStackTrace();
} catch (SipException e) { } catch (SipException e) {
e.printStackTrace(); e.printStackTrace();
} catch (ParseException e) {
e.printStackTrace();
} }
} }

View File

@ -6,7 +6,7 @@ import com.genersoft.iot.vmp.gb28181.SipLayer;
/** /**
* @Description:IPCameraSIP * @Description:IPCameraSIP
* @author: swwheihei * @author: songww
* @date: 202053 4:42:22 * @date: 202053 4:42:22
*/ */
public interface ISIPRequestProcessor { public interface ISIPRequestProcessor {

View File

@ -16,7 +16,7 @@ import gov.nist.javax.sip.header.CSeq;
/** /**
* @Description:ACK * @Description:ACK
* @author: swwheihei * @author: songww
* @date: 202053 5:31:45 * @date: 202053 5:31:45
*/ */
@Component @Component

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.request.ISIPRequestProcessor;
/** /**
* @Description: BYE * @Description: BYE
* @author: swwheihei * @author: songww
* @date: 202053 5:32:05 * @date: 202053 5:32:05
*/ */
@Component @Component

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.request.ISIPRequestProcessor;
/** /**
* @Description:CANCEL * @Description:CANCEL
* @author: swwheihei * @author: songww
* @date: 202053 5:32:23 * @date: 202053 5:32:23
*/ */
@Component @Component

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.request.ISIPRequestProcessor;
/** /**
* @Description:INVITE * @Description:INVITE
* @author: swwheihei * @author: songww
* @date: 202053 4:43:52 * @date: 202053 4:43:52
*/ */
@Component @Component

View File

@ -43,7 +43,7 @@ import com.genersoft.iot.vmp.utils.redis.RedisUtil;
/** /**
* @Description:MESSAGE * @Description:MESSAGE
* @author: swwheihei * @author: songww
* @date: 202053 5:32:41 * @date: 202053 5:32:41
*/ */
@Component @Component
@ -100,6 +100,7 @@ public class MessageRequestProcessor implements ISIPRequestProcessor {
Request request = evt.getRequest(); Request request = evt.getRequest();
SAXReader reader = new SAXReader(); SAXReader reader = new SAXReader();
reader.setEncoding("gbk");
Document xml; Document xml;
try { try {
xml = reader.read(new ByteArrayInputStream(request.getRawContent())); xml = reader.read(new ByteArrayInputStream(request.getRawContent()));
@ -375,7 +376,7 @@ public class MessageRequestProcessor implements ISIPRequestProcessor {
private Element getRootElement(RequestEvent evt) throws DocumentException { private Element getRootElement(RequestEvent evt) throws DocumentException {
Request request = evt.getRequest(); Request request = evt.getRequest();
SAXReader reader = new SAXReader(); SAXReader reader = new SAXReader();
reader.setEncoding("GB2312"); reader.setEncoding("gbk");
Document xml = reader.read(new ByteArrayInputStream(request.getRawContent())); Document xml = reader.read(new ByteArrayInputStream(request.getRawContent()));
return xml.getRootElement(); return xml.getRootElement();
} }

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.request.ISIPRequestProcessor;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202053 5:32:59 * @date: 202053 5:32:59
*/ */
@Component @Component

View File

@ -38,7 +38,7 @@ import gov.nist.javax.sip.header.Expires;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202053 4:47:25 * @date: 202053 4:47:25
*/ */
@Component @Component

View File

@ -17,7 +17,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.request.ISIPRequestProcessor;
/** /**
* @Description:SUBSCRIBE * @Description:SUBSCRIBE
* @author: swwheihei * @author: songww
* @date: 202053 5:31:20 * @date: 202053 5:31:20
*/ */
@Component @Component

View File

@ -1,5 +1,7 @@
package com.genersoft.iot.vmp.gb28181.transmit.response; package com.genersoft.iot.vmp.gb28181.transmit.response;
import java.text.ParseException;
import javax.sip.ResponseEvent; import javax.sip.ResponseEvent;
import com.genersoft.iot.vmp.conf.SipConfig; import com.genersoft.iot.vmp.conf.SipConfig;
@ -7,11 +9,11 @@ import com.genersoft.iot.vmp.gb28181.SipLayer;
/** /**
* @Description:IPCameraSIP * @Description:IPCameraSIP
* @author: swwheihei * @author: songww
* @date: 202053 4:42:22 * @date: 202053 4:42:22
*/ */
public interface ISIPResponseProcessor { public interface ISIPResponseProcessor {
public void process(ResponseEvent evt, SipLayer layer, SipConfig config); public void process(ResponseEvent evt, SipLayer layer, SipConfig config) throws ParseException;
} }

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
/** /**
* @Description: BYE * @Description: BYE
* @author: swwheihei * @author: songww
* @date: 202053 5:32:05 * @date: 202053 5:32:05
*/ */
@Component @Component

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
/** /**
* @Description:CANCEL * @Description:CANCEL
* @author: swwheihei * @author: songww
* @date: 202053 5:32:23 * @date: 202053 5:32:23
*/ */
@Component @Component

View File

@ -2,7 +2,6 @@ package com.genersoft.iot.vmp.gb28181.transmit.response.impl;
import java.text.ParseException; import java.text.ParseException;
import javax.sip.ClientTransaction;
import javax.sip.Dialog; import javax.sip.Dialog;
import javax.sip.InvalidArgumentException; import javax.sip.InvalidArgumentException;
import javax.sip.ResponseEvent; import javax.sip.ResponseEvent;
@ -22,9 +21,10 @@ import com.genersoft.iot.vmp.gb28181.SipLayer;
import com.genersoft.iot.vmp.gb28181.transmit.SIPProcessorFactory; import com.genersoft.iot.vmp.gb28181.transmit.SIPProcessorFactory;
import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor; import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
/** /**
* @Description:INVITE * @Description:INVITE
* @author: swwheihei * @author: songww
* @date: 202053 4:43:52 * @date: 202053 4:43:52
*/ */
@Component @Component
@ -35,17 +35,16 @@ public class InviteResponseProcessor implements ISIPResponseProcessor {
/** /**
* invite * invite
* *
* @param evt * @param evt
* * @throws ParseException
*/ */
@Override @Override
public void process(ResponseEvent evt, SipLayer layer, SipConfig config) { public void process(ResponseEvent evt, SipLayer layer, SipConfig config) throws ParseException {
try { try {
Response response = evt.getResponse(); Response response = evt.getResponse();
int statusCode = response.getStatusCode(); int statusCode = response.getStatusCode();
// trying不会回复 // trying不会回复
if (statusCode == Response.TRYING) { if (statusCode == Response.TRYING) {
} }
// 成功响应 // 成功响应
// 下发ack // 下发ack
@ -56,8 +55,9 @@ public class InviteResponseProcessor implements ISIPResponseProcessor {
// return; // return;
// } // }
// Dialog clientDialog = clientTransaction.getDialog(); // Dialog clientDialog = clientTransaction.getDialog();
//
// CSeqHeader clientCSeqHeader = (CSeqHeader) response.getHeader(CSeqHeader.NAME); // CSeqHeader clientCSeqHeader = (CSeqHeader)
// response.getHeader(CSeqHeader.NAME);
// long cseqId = clientCSeqHeader.getSeqNumber(); // long cseqId = clientCSeqHeader.getSeqNumber();
// /* // /*
// createAck函数创建的ackRequest会采用Invite响应的200OK中的contact字段中的地址作为目标地址。 // createAck函数创建的ackRequest会采用Invite响应的200OK中的contact字段中的地址作为目标地址。
@ -67,12 +67,30 @@ public class InviteResponseProcessor implements ISIPResponseProcessor {
// Request ackRequest = clientDialog.createAck(cseqId); // Request ackRequest = clientDialog.createAck(cseqId);
// SipURI requestURI = (SipURI) ackRequest.getRequestURI(); // SipURI requestURI = (SipURI) ackRequest.getRequestURI();
// ViaHeader viaHeader = (ViaHeader) response.getHeader(ViaHeader.NAME); // ViaHeader viaHeader = (ViaHeader) response.getHeader(ViaHeader.NAME);
// try {
// requestURI.setHost(viaHeader.getHost()); // requestURI.setHost(viaHeader.getHost());
// } catch (Exception e) {
// e.printStackTrace();
// }
// requestURI.setPort(viaHeader.getPort()); // requestURI.setPort(viaHeader.getPort());
// clientDialog.sendAck(ackRequest); // clientDialog.sendAck(ackRequest);
Dialog dialog = evt.getDialog(); Dialog dialog = evt.getDialog();
Request reqAck =dialog.createAck(1L); CSeqHeader cseq = (CSeqHeader) response.getHeader(CSeqHeader.NAME);
Request reqAck = dialog.createAck(cseq.getSeqNumber());
SipURI requestURI = (SipURI) reqAck.getRequestURI();
ViaHeader viaHeader = (ViaHeader) response.getHeader(ViaHeader.NAME);
// String viaHost =viaHeader.getHost();
//getHost()函数取回的IP地址是“[xxx.xxx.xxx.xxx:yyyy]”的格式需用正则表达式截取为“xxx.xxx.xxx.xxx"格式
// Pattern p = Pattern.compile("(?<=//|)((\\w)+\\.)+\\w+");
// Matcher matcher = p.matcher(viaHeader.getHost());
// if (matcher.find()) {
// requestURI.setHost(matcher.group());
// }
requestURI.setHost(viaHeader.getHost());
requestURI.setPort(viaHeader.getPort());
reqAck.setRequestURI(requestURI);
dialog.sendAck(reqAck); dialog.sendAck(reqAck);
} }
} catch (InvalidArgumentException | SipException e) { } catch (InvalidArgumentException | SipException e) {

View File

@ -10,7 +10,7 @@ import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202053 5:32:59 * @date: 202053 5:32:59
*/ */
@Component @Component

View File

@ -7,7 +7,7 @@ import java.util.Locale;
/** /**
* @Description:ISO 8601 * @Description:ISO 8601
* @author: swwheihei * @author: songww
* @date: 202058 3:24:42 * @date: 202058 3:24:42
*/ */
public class DateUtil { public class DateUtil {

View File

@ -18,11 +18,11 @@ import com.genersoft.iot.vmp.gb28181.transmit.cmd.impl.SIPCommander;
/** /**
* @Description: ZLMediaServerhook * @Description: ZLMediaServerhook
* @author: swwheihei * @author: songww
* @date: 202058 10:46:48 * @date: 202058 10:46:48
*/ */
@RestController @RestController
@RequestMapping("/hook/zlm") @RequestMapping("/index/hook")
public class ZLMHttpHookListener { public class ZLMHttpHookListener {
private final static Logger logger = LoggerFactory.getLogger(ZLMHttpHookListener.class); private final static Logger logger = LoggerFactory.getLogger(ZLMHttpHookListener.class);

View File

@ -6,7 +6,7 @@ import com.genersoft.iot.vmp.gb28181.bean.Device;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202056 2:14:31 * @date: 202056 2:14:31
*/ */
public interface IVideoManagerStorager { public interface IVideoManagerStorager {

View File

@ -8,7 +8,7 @@ import com.genersoft.iot.vmp.conf.VManagerConfig;
/** /**
* @Description: * @Description:
* @author: swwheihei * @author: songww
* @date: 202056 2:15:16 * @date: 202056 2:15:16
*/ */
@Component @Component

View File

@ -11,7 +11,7 @@ import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
/** /**
* @Description:-jdbc * @Description:-jdbc
* @author: swwheihei * @author: songww
* @date: 202056 2:28:12 * @date: 202056 2:28:12
*/ */
@Component("jdbcStorager") @Component("jdbcStorager")

View File

@ -13,7 +13,7 @@ import com.genersoft.iot.vmp.utils.redis.RedisUtil;
/** /**
* @Description:-redis * @Description:-redis
* @author: swwheihei * @author: songww
* @date: 202056 2:31:42 * @date: 202056 2:31:42
*/ */
@Component("redisStorager") @Component("redisStorager")

View File

@ -7,7 +7,7 @@ import org.springframework.stereotype.Component;
/** /**
* @Description:spring beanspringbean * @Description:spring beanspringbean
* @author: swwheihei * @author: songww
* @date: 2019625 4:51:52 * @date: 2019625 4:51:52
* *
*/ */

View File

@ -10,7 +10,7 @@ import com.alibaba.fastjson.serializer.SerializerFeature;
/** /**
* @Description:使fastjsonredis * @Description:使fastjsonredis
* @author: swwheihei * @author: songww
* @date: 202056 8:40:11 * @date: 202056 8:40:11
*/ */
public class FastJsonRedisSerializer<T> implements RedisSerializer<T> { public class FastJsonRedisSerializer<T> implements RedisSerializer<T> {

View File

@ -13,7 +13,7 @@ import org.springframework.util.CollectionUtils;
/** /**
* @Description:Redis * @Description:Redis
* @author: swwheihei * @author: songww
* @date: 202056 8:27:29 * @date: 202056 8:27:29
*/ */
@Component @Component

View File

@ -26,7 +26,8 @@ spring:
server: server:
port: 8080 port: 8080
sip: sip:
ip: 10.200.64.63 # ip: 10.200.64.63
ip: 192.168.0.102
port: 5060 port: 5060
# 根据国标6.1.2中规定domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码由省级、市级、区级、基层编号组成参照GB/T 2260-2007 # 根据国标6.1.2中规定domain宜采用ID统一编码的前十位编码。国标附录D中定义前8位为中心编码由省级、市级、区级、基层编号组成参照GB/T 2260-2007
# 后两位为行业编码定义参照附录D.3 # 后两位为行业编码定义参照附录D.3
@ -34,7 +35,8 @@ sip:
domain: 3701020049 domain: 3701020049
id: 37010200492000000001 id: 37010200492000000001
# 默认设备认证密码,后续扩展使用设备单独密码 # 默认设备认证密码,后续扩展使用设备单独密码
password: admin password: admin123
media: media:
ip: 10.200.64.88 # ip: 10.200.64.88
ip: 192.168.0.102
port: 10000 port: 10000

Binary file not shown.

Before

Width:  |  Height:  |  Size: 33 KiB

After

Width:  |  Height:  |  Size: 169 KiB