From 421c2f56020bfe60b0e0c90e9d509abf03354dab Mon Sep 17 00:00:00 2001 From: panlinlin <648540858@qq.com> Date: Mon, 1 Mar 2021 18:12:56 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BD=BF=E7=94=A8jainsip=E7=9A=84=E6=96=B9?= =?UTF-8?q?=E5=BC=8F=E8=A7=A3=E6=9E=90sdp?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../genersoft/iot/vmp/gb28181/sdp/Codec.java | 65 ----- .../iot/vmp/gb28181/sdp/MediaDescription.java | 123 ---------- .../iot/vmp/gb28181/sdp/RFC4566_28181.java | 51 ---- .../iot/vmp/gb28181/sdp/SdpLine.java | 38 --- .../iot/vmp/gb28181/sdp/SdpParser.java | 230 ------------------ .../vmp/gb28181/sdp/SessionDescription.java | 162 ------------ .../transmit/cmd/impl/SIPCommander.java | 1 - .../request/impl/InviteRequestProcessor.java | 107 +++++--- web_src/.postcssrc.js | 2 +- 9 files changed, 80 insertions(+), 699 deletions(-) delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/Codec.java delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/MediaDescription.java delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/RFC4566_28181.java delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpLine.java delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpParser.java delete mode 100755 src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SessionDescription.java diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/Codec.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/Codec.java deleted file mode 100755 index 4ab6f8f8..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/Codec.java +++ /dev/null @@ -1,65 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2010 Yohann Martineau -*/ - -package com.genersoft.iot.vmp.gb28181.sdp; - -public class Codec { - - private int payloadType; - private String name; - - public int getPayloadType() { - return payloadType; - } - - public void setPayloadType(int payloadType) { - this.payloadType = payloadType; - } - - public String getName() { - return name; - } - - public void setName(String name) { - this.name = name; - } - - @Override - public boolean equals(Object obj) { - if (!(obj instanceof Codec)) { - return false; - } - Codec codec = (Codec)obj; - if (codec.getName() == null) { - return name == null; - } - return codec.getName().equalsIgnoreCase(name); - } - - @Override - public String toString() { - StringBuffer buf = new StringBuffer(); - buf.append(RFC4566_28181.TYPE_ATTRIBUTE).append(RFC4566_28181.SEPARATOR); - buf.append(RFC4566_28181.ATTR_RTPMAP).append(RFC4566_28181.ATTR_SEPARATOR); - buf.append(payloadType).append(" ").append(name).append("/"); - buf.append(9000).append("\r\n"); - return buf.toString(); - } - -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/MediaDescription.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/MediaDescription.java deleted file mode 100755 index 50f361f1..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/MediaDescription.java +++ /dev/null @@ -1,123 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2007, 2008, 2009, 2010 Yohann Martineau - */ - -package com.genersoft.iot.vmp.gb28181.sdp; - -import java.net.Inet4Address; -import java.net.Inet6Address; -import java.net.InetAddress; -import java.util.Hashtable; -import java.util.List; - -public class MediaDescription { - - private String type; - private InetAddress ipAddress; - // attributes not codec-related - private Hashtable attributes; - private int port; - private List codecs; - - public String getType() { - return type; - } - - public void setType(String type) { - this.type = type; - } - - public Hashtable getAttributes() { - return attributes; - } - - public void setAttributes(Hashtable attributes) { - this.attributes = attributes; - } - - public InetAddress getIpAddress() { - return ipAddress; - } - - public void setIpAddress(InetAddress ipAddress) { - this.ipAddress = ipAddress; - } - - public int getPort() { - return port; - } - - public void setPort(int port) { - this.port = port; - } - - public List getCodecs() { - return codecs; - } - - public void setCodecs(List codecs) { - this.codecs = codecs; - } - - @Override - public String toString() { - StringBuffer buf = new StringBuffer(); - buf.append(RFC4566_28181.TYPE_MEDIA).append(RFC4566_28181.SEPARATOR); - buf.append(type).append(" ").append(port); - buf.append(" RTP/AVP"); - if (codecs != null) { - for (Codec codec: codecs) { - buf.append(" "); - buf.append(codec.getPayloadType()); - } - buf.append("\r\n"); - } - if (ipAddress != null) { - int ipVersion; - if (ipAddress instanceof Inet4Address) { - ipVersion = 4; - } else if (ipAddress instanceof Inet6Address) { - ipVersion = 6; - } else { - throw new RuntimeException("unknown ip version: " + ipAddress); - } - buf.append(RFC4566_28181.TYPE_CONNECTION).append(RFC4566_28181.SEPARATOR); - buf.append("IN IP").append(ipVersion).append(" "); - buf.append(ipAddress.getHostAddress()).append("\r\n"); - } - if (codecs != null) { - for (Codec codec: codecs) { - buf.append(codec.toString()); - } - } - - if (attributes != null) { - for (String attributeName: attributes.keySet()) { - buf.append(RFC4566_28181.TYPE_ATTRIBUTE).append(RFC4566_28181.SEPARATOR); - buf.append(attributeName); - String attributeValue = attributes.get(attributeName); - if (attributeValue != null && !"".equals(attributeValue.trim())) { - buf.append(":").append(attributeValue); - } - buf.append("\r\n"); - } - } - return buf.toString(); - } - -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/RFC4566_28181.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/RFC4566_28181.java deleted file mode 100755 index dd6019be..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/RFC4566_28181.java +++ /dev/null @@ -1,51 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2007, 2008, 2009, 2010 Yohann Martineau -*/ - -package com.genersoft.iot.vmp.gb28181.sdp; - -public class RFC4566_28181 { - - public static final char VERSION = '0'; - - public static final char TYPE_VERSION = 'v'; - public static final char TYPE_ORIGIN = 'o'; - public static final char TYPE_SUBJECT = 's'; - public static final char TYPE_INFO = 'i'; - public static final char TYPE_URI = 'u'; - public static final char TYPE_EMAIL = 'e'; - public static final char TYPE_PHONE = 'p'; - public static final char TYPE_CONNECTION = 'c'; - public static final char TYPE_BANDWITH = 'b'; - public static final char TYPE_TIME = 't'; - public static final char TYPE_REPEAT = 'r'; - public static final char TYPE_ZONE = 'z'; - public static final char TYPE_KEY = 'k'; - public static final char TYPE_ATTRIBUTE = 'a'; - public static final char TYPE_MEDIA = 'm'; - public static final char TYPE_SSRC = 'y'; - public static final char TYPE_MEDIA_DES = 'f'; - - public static final char SEPARATOR = '='; - public static final char ATTR_SEPARATOR = ':'; - - public static final String MEDIA_AUDIO = "audio"; - - public static final String ATTR_RTPMAP = "rtpmap"; - public static final String ATTR_SENDRECV = "sendrecv"; -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpLine.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpLine.java deleted file mode 100755 index 2d573382..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpLine.java +++ /dev/null @@ -1,38 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2007, 2008, 2009, 2010 Yohann Martineau -*/ - -package com.genersoft.iot.vmp.gb28181.sdp; - -public class SdpLine { - private char type; - private String value; - public char getType() { - return type; - } - public void setType(char type) { - this.type = type; - } - public String getValue() { - return value; - } - public void setValue(String value) { - this.value = value; - } - -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpParser.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpParser.java deleted file mode 100755 index fb8d499f..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SdpParser.java +++ /dev/null @@ -1,230 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2007, 2008, 2009, 2010 Yohann Martineau -*/ - -package com.genersoft.iot.vmp.gb28181.sdp; - -import java.io.BufferedReader; -import java.io.ByteArrayInputStream; -import java.io.IOException; -import java.io.InputStreamReader; -import java.net.InetAddress; -import java.util.ArrayList; -import java.util.Hashtable; -import java.util.List; - -public class SdpParser { - - public SessionDescription parse(byte[] body) throws IOException { - if (body == null || body.length == 0) { - return null; - } - ByteArrayInputStream in = new ByteArrayInputStream(body); - InputStreamReader inputStreamReader = new InputStreamReader(in); - BufferedReader reader = new BufferedReader(inputStreamReader); - SessionDescription sessionDescription = new SessionDescription(); - - //version - - String line = reader.readLine(); - if (line.length() < 3) { - return null; - } - if (line.charAt(0) != RFC4566_28181.TYPE_VERSION - || line.charAt(1) != RFC4566_28181.SEPARATOR - || line.charAt(2) != RFC4566_28181.VERSION) { - return null; - } - - //origin - - line = reader.readLine(); - if (line.length() < 3) { - return null; - } - if (line.charAt(0) != RFC4566_28181.TYPE_ORIGIN - || line.charAt(1) != RFC4566_28181.SEPARATOR) { - return null; - } - line = line.substring(2); - String[] originArr = line.split(" "); - if (originArr == null || originArr.length != 6) { - return null; - } - sessionDescription.setUsername(originArr[0]); - sessionDescription.setId(Long.parseLong(originArr[1])); - sessionDescription.setVersion(Long.parseLong(originArr[2])); - sessionDescription.setIpAddress(InetAddress.getByName(originArr[5])); - - //name - - line = reader.readLine(); - if (line.length() < 3) { - return null; - } - if (line.charAt(0) != RFC4566_28181.TYPE_SUBJECT - || line.charAt(1) != RFC4566_28181.SEPARATOR) { - return null; - } - sessionDescription.setName(line.substring(2)); - - //session connection and attributes - Hashtable sessionAttributes = new Hashtable(); - sessionDescription.setAttributes(sessionAttributes); - - while ((line = reader.readLine()) != null - && line.charAt(0) != RFC4566_28181.TYPE_MEDIA) { - if (line.length() > 3 - && line.charAt(0) == RFC4566_28181.TYPE_CONNECTION - && line.charAt(1) == RFC4566_28181.SEPARATOR) { - String connection = parseConnection(line.substring(2)); - if (connection == null) { - continue; - } - sessionDescription.setIpAddress(InetAddress.getByName(connection)); - } else if (line.length() > 3 - && line.charAt(0) == RFC4566_28181.TYPE_ATTRIBUTE - && line.charAt(1) == RFC4566_28181.SEPARATOR) { - String value = line.substring(2); - int pos = value.indexOf(RFC4566_28181.ATTR_SEPARATOR); - if (pos > -1) { - sessionAttributes.put(value.substring(0, pos), - value.substring(pos + 1)); - } else { - sessionAttributes.put(value, ""); - } - } - } - if (line == null) { - return null; - } - //we are at the first media line - - ArrayList mediaLines = new ArrayList(); - do { - if (line.length() < 2) { - return null; - } - if (line.charAt(1) != RFC4566_28181.SEPARATOR) { - return null; - } - if (line.charAt(0) == RFC4566_28181.TYPE_SSRC) { - sessionDescription.setSsrc(line.length() >=2 ?line.substring(2):""); - }else if (line.charAt(0) == RFC4566_28181.TYPE_MEDIA_DES) { - sessionDescription.setGbMediaDescriptions(line.length() >=2 ?line.substring(2):""); - }else { - SdpLine mediaLine = new SdpLine(); - mediaLine.setType(line.charAt(0)); - mediaLine.setValue(line.substring(2)); - mediaLines.add(mediaLine); - } - - } - while ((line = reader.readLine()) != null ); - - ArrayList mediaDescriptions = new ArrayList(); - sessionDescription.setMediaDescriptions(mediaDescriptions); - - for (SdpLine sdpLine : mediaLines) { - MediaDescription mediaDescription; - if (sdpLine.getType() == RFC4566_28181.TYPE_MEDIA) { - String[] mediaArr = sdpLine.getValue().split(" "); - if (mediaArr == null || mediaArr.length < 4) { - return null; - } - mediaDescription = new MediaDescription(); - mediaDescription.setType(mediaArr[0]); - //TODO manage port range - mediaDescription.setPort(Integer.parseInt(mediaArr[1])); - mediaDescription.setAttributes(new Hashtable()); - List codecs = new ArrayList(); - for (int i = 3; i < mediaArr.length; ++i) { - int payloadType = Integer.parseInt(mediaArr[i]); - Codec codec = new Codec(); - codec.setPayloadType(payloadType); - codec.setName("unsupported"); - codecs.add(codec); - } - mediaDescription.setCodecs(codecs); - mediaDescriptions.add(mediaDescription); - } else { - mediaDescription = mediaDescriptions.get(mediaDescriptions.size() - 1); - String sdpLineValue = sdpLine.getValue(); - if (sdpLine.getType() == RFC4566_28181.TYPE_CONNECTION) { - String ipAddress = parseConnection(sdpLineValue); - mediaDescription.setIpAddress(InetAddress.getByName(ipAddress)); - } else if (sdpLine.getType() == RFC4566_28181.TYPE_ATTRIBUTE) { - Hashtable attributes = mediaDescription.getAttributes(); - int pos = sdpLineValue.indexOf(RFC4566_28181.ATTR_SEPARATOR); - if (pos > -1) { - String name = sdpLineValue.substring(0, pos); - String value = sdpLineValue.substring(pos + 1); - pos = value.indexOf(" "); - if (pos > -1) { - int payloadType; - try { - payloadType = Integer.parseInt(value.substring(0, pos)); - List codecs = mediaDescription.getCodecs(); - for (Codec codec: codecs) { - if (codec.getPayloadType() == payloadType) { - value = value.substring(pos + 1); - pos = value.indexOf("/"); - if (pos > -1) { - value = value.substring(0, pos); - codec.setName(value); - } - break; - } - } - } catch (NumberFormatException e) { - attributes.put(name, value); - } - } else { - attributes.put(name, value); - } - } else { - attributes.put(sdpLineValue, ""); - } - } - } - } - sessionDescription.setMediaDescriptions(mediaDescriptions); - - for (MediaDescription description : mediaDescriptions) { - if (description.getIpAddress() == null) { - InetAddress sessionAddress = sessionDescription.getIpAddress(); - if (sessionAddress == null) { - return null; - } - description.setIpAddress(sessionAddress); - } - } - - - return sessionDescription; - } - - private String parseConnection(String line) { - String[] connectionArr = line.split(" "); - if (connectionArr == null || connectionArr.length != 3) { - return null; - } - return connectionArr[2]; - } - -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SessionDescription.java b/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SessionDescription.java deleted file mode 100755 index ad68099b..00000000 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/sdp/SessionDescription.java +++ /dev/null @@ -1,162 +0,0 @@ -/* - This file is part of Peers, a java SIP softphone. - - This program is free software: you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation, either version 3 of the License, or - any later version. - - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program. If not, see . - - Copyright 2007, 2008, 2009, 2010 Yohann Martineau -*/ - -package com.genersoft.iot.vmp.gb28181.sdp; - -import java.net.Inet4Address; -import java.net.Inet6Address; -import java.net.InetAddress; -import java.util.Hashtable; -import java.util.List; - -public class SessionDescription { - - private long id; - private long version; - private String name; - private String username; - private InetAddress ipAddress; - private List mediaDescriptions; - private Hashtable attributes; - private String ssrc; - private String gbMediaDescriptions; - - public SessionDescription() { - } - - public long getId() { - return id; - } - - public void setId(long id) { - this.id = id; - } - - public InetAddress getIpAddress() { - return ipAddress; - } - - public void setIpAddress(InetAddress ipAddress) { - this.ipAddress = ipAddress; - } - - public List getMediaDescriptions() { - return mediaDescriptions; - } - - public void setMediaDescriptions(List mediaDescriptions) { - this.mediaDescriptions = mediaDescriptions; - } - - public String getName() { - return name; - } - - public void setName(String name) { - this.name = name; - } - - public String getUsername() { - return username; - } - - public void setUsername(String username) { - this.username = username; - } - - public long getVersion() { - return version; - } - - public void setVersion(long version) { - this.version = version; - } - - public Hashtable getAttributes() { - return attributes; - } - - public void setAttributes(Hashtable attributes) { - this.attributes = attributes; - } - - public String getSsrc() { - return ssrc; - } - - public void setSsrc(String ssrc) { - this.ssrc = ssrc; - } - - public String getGbMediaDescriptions() { - return gbMediaDescriptions; - } - - public void setGbMediaDescriptions(String gbMediaDescriptions) { - this.gbMediaDescriptions = gbMediaDescriptions; - } - - @Override - public String toString() { - StringBuilder buf = new StringBuilder(); - buf.append("v=0\r\n"); - buf.append("o=").append(username).append(" ").append(id); - buf.append(" ").append(version); - int ipVersion; - if (ipAddress instanceof Inet4Address) { - ipVersion = 4; - } else if (ipAddress instanceof Inet6Address) { - ipVersion = 6; - } else { - throw new RuntimeException("unknown ip version: " + ipAddress); - } - buf.append(" IN IP").append(ipVersion).append(" "); - String hostAddress = ipAddress.getHostAddress(); - buf.append(hostAddress).append("\r\n"); - buf.append("s=").append(name).append("\r\n"); - buf.append("c=IN IP").append(ipVersion).append(" "); - buf.append(hostAddress).append("\r\n"); - buf.append("t=0 0\r\n"); - if (attributes != null){ - for (String attributeName: attributes.keySet()) { - String attributeValue = attributes.get(attributeName); - buf.append("a=").append(attributeName); - if (attributeValue != null && !"".equals(attributeValue.trim())) { - buf.append(":"); - buf.append(attributeValue); - buf.append("\r\n"); - } - } - } - if (mediaDescriptions != null){ - for (MediaDescription mediaDescription: mediaDescriptions) { - buf.append(mediaDescription.toString()); - } - } - - if (ssrc != null){ - buf.append("y=").append(ssrc).append("\r\n"); - } - if (gbMediaDescriptions != null){ - buf.append("f=").append(gbMediaDescriptions).append("\r\n"); - } - return buf.toString(); - } - -} diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/cmd/impl/SIPCommander.java b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/cmd/impl/SIPCommander.java index 6bab8090..980c8565 100644 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/cmd/impl/SIPCommander.java +++ b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/cmd/impl/SIPCommander.java @@ -374,7 +374,6 @@ public class SIPCommander implements ISIPCommander { if ("TCP-PASSIVE".equals(streamMode)) { // tcp被动模式 content.append("a=setup:passive\r\n"); content.append("a=connection:new\r\n"); - } else if ("TCP-ACTIVE".equals(streamMode)) { // tcp主动模式 } else if ("TCP-ACTIVE".equals(streamMode)) { // tcp主动模式 content.append("a=setup:active\r\n"); content.append("a=connection:new\r\n"); diff --git a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/request/impl/InviteRequestProcessor.java b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/request/impl/InviteRequestProcessor.java index 9d0a9a3f..7e9e626b 100644 --- a/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/request/impl/InviteRequestProcessor.java +++ b/src/main/java/com/genersoft/iot/vmp/gb28181/transmit/request/impl/InviteRequestProcessor.java @@ -113,45 +113,84 @@ public class InviteRequestProcessor extends SIPRequestAbstractProcessor { } // 解析sdp消息, 使用jainsip 自带的sdp解析方式 String contentString = new String(request.getRawContent()); - SessionDescription sdp = SdpFactory.getInstance().createSessionDescription(contentString); - // TODO 区分TCP发流还是udp, 当前默认udp + // jainSip不支持y=字段, 移除移除以解析。 + int ssrcIndex = contentString.indexOf("y="); + String ssrc = contentString.substring(ssrcIndex + 2, contentString.length()) + .replace("\r\n", "").replace("\n", ""); + + String substring = contentString.substring(0, contentString.indexOf("y=")); + SessionDescription sdp = SdpFactory.getInstance().createSessionDescription(substring); + // 获取支持的格式 Vector mediaDescriptions = sdp.getMediaDescriptions(true); // 查看是否支持PS 负载96 String ip = null; int port = -1; + boolean recvonly = false; + boolean mediaTransmissionTCP = false; + Boolean tcpActive = null; for (int i = 0; i < mediaDescriptions.size(); i++) { MediaDescription mediaDescription = (MediaDescription)mediaDescriptions.get(i); Media media = mediaDescription.getMedia(); - port = media.getMediaPort(); - } -// for (MediaDescription mediaDescription : mediaDescriptions) { + + Vector mediaFormats = media.getMediaFormats(false); + if (mediaFormats.contains("96")) { + port = media.getMediaPort(); + String mediaType = media.getMediaType(); + String protocol = media.getProtocol(); + + // 区分TCP发流还是udp, 当前默认udp + if ("TCP/RTP/AVP".equals(protocol)) { + String setup = mediaDescription.getAttribute("setup"); + if (setup != null) { + mediaTransmissionTCP = true; + if ("active".equals(setup)) { + tcpActive = true; + }else if ("passive".equals(setup)) { + tcpActive = false; + } + } + } +// Vector attributes = mediaDescription.getAttributes(false); +// for (Object attributeObj : attributes) { +// Attribute attribute = (Attribute)attributeObj; +// String name = attribute.getName(); +// switch (name){ +// case "recvonly": +// recvonly = true; +// break; +// case "rtpmap": +// case "connection": +// break; +// case "setup": +// mediaTransmissionTCP = true; +// if ("active".equals(attribute.getValue())) { // tcp主动模式 +// tcpActive = true; +// }else if ("passive".equals(attribute.getValue())){ // tcp被动模式 +// tcpActive = false; +// } +// break; // -// List codecs = mediaDescription.getCodecs(); -// for (Codec codec : codecs) { -// if("96".equals(codec.getPayloadType()) || "PS".equals(codec.getName()) || "ps".equals(codec.getName())) { -// // TODO 这里很慢 -// ip = mediaDescription.getIpAddress().getHostName(); -// port = mediaDescription.getPort(); -// break; +// } +// if ("recvonly".equals(name)) { +// recvonly = true; +// } +// +// String value = attribute.getValue(); // } -// } -// } -// if (ip == null || port == -1) { // TODO 没有合适的视频流格式, 可配置是否使用第一个media信息 -// if (mediaDescriptions.size() > 0) { -// ip = mediaDescriptions.get(0).getIpAddress().getHostName(); -// port = mediaDescriptions.get(0).getPort(); -// } -// } -// -// if (ip == null || port == -1) { -// response488Ack(evt); -// return; -// } -// -// -// String ssrc = sdp.getSsrc(); + break; + } + } + if (port == -1) { + // 回复不支持的格式 + response415Ack(evt); // 不支持的格式,发415 + return; + } + String username = sdp.getOrigin().getUsername(); + String addressStr = sdp.getOrigin().getAddress(); + String sessionName = sdp.getSessionName().getValue(); + logger.info("[上级点播]用户:{}, 地址:{}:{}, ssrc:{}", username, addressStr, port, ssrc); // // Device device = storager.queryVideoDeviceByPlatformIdAndChannelId(platformId, channelId); // if (device == null) { @@ -277,6 +316,18 @@ public class InviteRequestProcessor extends SIPRequestAbstractProcessor { getServerTransaction(evt).sendResponse(response); } + /*** + * 回复415 不支持的媒体类型 + * @param evt + * @throws SipException + * @throws InvalidArgumentException + * @throws ParseException + */ + private void response415Ack(RequestEvent evt) throws SipException, InvalidArgumentException, ParseException { + Response response = getMessageFactory().createResponse(Response.UNSUPPORTED_MEDIA_TYPE, evt.getRequest()); + getServerTransaction(evt).sendResponse(response); + } + /*** * 回复488 * @param evt diff --git a/web_src/.postcssrc.js b/web_src/.postcssrc.js index 2fb7b665..f8737a12 100644 --- a/web_src/.postcssrc.js +++ b/web_src/.postcssrc.js @@ -7,7 +7,7 @@ module.exports = { // to edit target browsers: use "browserslist" field in package.json "autoprefixer": {}, 'postcss-pxtorem': { - rootValue: 24, + rootValue: 16, propList: ['font-size'] // 只转化font-size } }