From e48fa711a3664bece9b3e58840a75fe7c05bc47c Mon Sep 17 00:00:00 2001
From: panlinlin <648540858@qq.com>
Date: 星期六, 08 五月 2021 17:14:05 +0800
Subject: [PATCH] 添加截图(快照)功能

---
 src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java |   57 ++++++++++-----------------------------------------------
 1 files changed, 10 insertions(+), 47 deletions(-)

diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
index 669b360..7368c36 100644
--- a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
+++ b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/response/impl/InviteResponseProcessor.java
@@ -2,35 +2,31 @@
 
 import java.text.ParseException;
 
-import javax.sip.Dialog;
-import javax.sip.InvalidArgumentException;
-import javax.sip.ResponseEvent;
-import javax.sip.SipException;
+import javax.sip.*;
 import javax.sip.address.SipURI;
 import javax.sip.header.CSeqHeader;
-import javax.sip.header.ViaHeader;
 import javax.sip.message.Request;
 import javax.sip.message.Response;
 
+import gov.nist.javax.sip.ResponseEventExt;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Component;
 
 import com.genersoft.iot.vmp.conf.SipConfig;
 import com.genersoft.iot.vmp.gb28181.SipLayer;
-import com.genersoft.iot.vmp.gb28181.transmit.SIPProcessorFactory;
 import com.genersoft.iot.vmp.gb28181.transmit.response.ISIPResponseProcessor;
 
 
 /**
- * @Description:澶勭悊INVITE鍝嶅簲
- * @author: songww
- * @date: 2020骞�5鏈�3鏃� 涓嬪崍4:43:52
+ * @Description:澶勭悊INVITE鍝嶅簲
+ * @author: swwheihei
+ * @date: 2020骞�5鏈�3鏃� 涓嬪崍4:43:52
  */
 @Component
 public class InviteResponseProcessor implements ISIPResponseProcessor {
 
-	private final static Logger logger = LoggerFactory.getLogger(SIPProcessorFactory.class);
+	 private final static Logger logger = LoggerFactory.getLogger(InviteResponseProcessor.class);
 
 	/**
 	 * 澶勭悊invite鍝嶅簲
@@ -49,48 +45,15 @@
 			// 鎴愬姛鍝嶅簲
 			// 涓嬪彂ack
 			if (statusCode == Response.OK) {
-				// ClientTransaction clientTransaction = evt.getClientTransaction();
-				// if(clientTransaction == null){
-				// logger.error("鍥炲ACK鏃讹紝clientTransaction涓簄ull >>> {}",response);
-				// return;
-				// }
-				// Dialog clientDialog = clientTransaction.getDialog();
-
-				// CSeqHeader clientCSeqHeader = (CSeqHeader)
-				// response.getHeader(CSeqHeader.NAME);
-				// long cseqId = clientCSeqHeader.getSeqNumber();
-				// /*
-				// createAck鍑芥暟锛屽垱寤虹殑ackRequest锛屼細閲囩敤Invite鍝嶅簲鐨�200OK锛屼腑鐨刢ontact瀛楁涓殑鍦板潃锛屼綔涓虹洰鏍囧湴鍧�銆�
-				// 鏈夌殑缁堢浼犱笂鏉ョ殑鍙兘杩樻槸鍐呯綉鍦板潃锛屼細閫犳垚ack鍙戦�佷笉鍑哄幓銆傛帴鍙椾笉鍒伴煶瑙嗛娴�
-				// 鎵�浠ュ湪姝ゅ缁熶竴鏇挎崲鍦板潃銆傚拰鍝嶅簲娑堟伅鐨刅ia澶翠腑鐨勫湴鍧�淇濇寔涓�鑷淬��
-				// */
-				// Request ackRequest = clientDialog.createAck(cseqId);
-				// SipURI requestURI = (SipURI) ackRequest.getRequestURI();
-				// ViaHeader viaHeader = (ViaHeader) response.getHeader(ViaHeader.NAME);
-				// try {
-				// requestURI.setHost(viaHeader.getHost());
-				// } catch (Exception e) {
-				// e.printStackTrace();
-				// }
-				// requestURI.setPort(viaHeader.getPort());
-				// clientDialog.sendAck(ackRequest);
-
+				ResponseEventExt event = (ResponseEventExt)evt;
 				Dialog dialog = evt.getDialog();
 				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()鍑芥暟鍙栧洖鐨処P鍦板潃鏄�淸xxx.xxx.xxx.xxx:yyyy]鈥濈殑鏍煎紡锛岄渶鐢ㄦ鍒欒〃杈惧紡鎴彇涓衡�渪xx.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());
+				requestURI.setHost(event.getRemoteIpAddress());
+				requestURI.setPort(event.getRemotePort());
 				reqAck.setRequestURI(requestURI);
+				logger.info("鍚� " + event.getRemoteIpAddress() + ":" + event.getRemotePort() + "鍥炲ack");
 				dialog.sendAck(reqAck);
 			}
 		} catch (InvalidArgumentException | SipException e) {

--
Gitblit v1.8.0