去除ssrc作为流ID传递,ssrc只作为sdp消息使用。动态端口的情况下支持固定流地址,同时支持未点播时直接播放流地址,代码自动发起点播
This commit is contained in:
@@ -4,13 +4,16 @@ import java.math.BigInteger;
|
||||
import java.text.DecimalFormat;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.UUID;
|
||||
|
||||
import com.alibaba.fastjson.JSON;
|
||||
import com.alibaba.fastjson.JSONArray;
|
||||
import com.genersoft.iot.vmp.common.StreamInfo;
|
||||
import com.genersoft.iot.vmp.conf.MediaServerConfig;
|
||||
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
||||
import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
|
||||
import com.genersoft.iot.vmp.utils.IpUtil;
|
||||
import com.genersoft.iot.vmp.vmanager.service.IPlayService;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
@@ -43,6 +46,9 @@ public class ZLMHttpHookListener {
|
||||
@Autowired
|
||||
private SIPCommander cmder;
|
||||
|
||||
@Autowired
|
||||
private IPlayService playService;
|
||||
|
||||
@Autowired
|
||||
private IVideoManagerStorager storager;
|
||||
|
||||
@@ -52,6 +58,9 @@ public class ZLMHttpHookListener {
|
||||
@Autowired
|
||||
private ZLMHttpHookSubscribe subscribe;
|
||||
|
||||
@Value("${media.autoApplyPlay}")
|
||||
private boolean autoApplyPlay;
|
||||
|
||||
@Value("${media.ip}")
|
||||
private String mediaIp;
|
||||
|
||||
@@ -135,34 +144,6 @@ public class ZLMHttpHookListener {
|
||||
ZLMHttpHookSubscribe.Event subscribe = this.subscribe.getSubscribe(ZLMHttpHookSubscribe.HookType.on_publish, json);
|
||||
if (subscribe != null) subscribe.response(json);
|
||||
|
||||
// if ("rtp".equals(app)) {
|
||||
// String ssrc = new DecimalFormat("0000000000").format(Integer.parseInt(streamId, 16));
|
||||
// StreamInfo streamInfoForPlay = storager.queryPlayBySSRC(ssrc);
|
||||
// if ("rtp".equals(app) && streamInfoForPlay != null ) {
|
||||
// MediaServerConfig mediaInfo = storager.getMediaInfo();
|
||||
// streamInfoForPlay.setFlv(String.format("http://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlay.setWs_flv(String.format("ws://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlay.setFmp4(String.format("http://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlay.setWs_fmp4(String.format("ws://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlay.setRtmp(String.format("rtmp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtmpPort(), streamId));
|
||||
// streamInfoForPlay.setHls(String.format("http://%s:%s/rtp/%s/hls.m3u8", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlay.setRtsp(String.format("rtsp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtspPort(), streamId));
|
||||
// storager.startPlay(streamInfoForPlay);
|
||||
// }
|
||||
//
|
||||
// StreamInfo streamInfoForPlayBack = storager.queryPlaybackBySSRC(ssrc);
|
||||
// if ("rtp".equals(app) && streamInfoForPlayBack != null ) {
|
||||
// MediaServerConfig mediaInfo = storager.getMediaInfo();
|
||||
// streamInfoForPlayBack.setFlv(String.format("http://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlayBack.setWs_flv(String.format("ws://%s:%s/rtp/%s.flv", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlayBack.setFmp4(String.format("http://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlayBack.setWs_fmp4(String.format("ws://%s:%s/rtp/%s.live.mp4", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlayBack.setRtmp(String.format("rtmp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtmpPort(), streamId));
|
||||
// streamInfoForPlayBack.setHls(String.format("http://%s:%s/rtp/%s/hls.m3u8", mediaInfo.getWanIp(), mediaInfo.getHttpPort(), streamId));
|
||||
// streamInfoForPlayBack.setRtsp(String.format("rtsp://%s:%s/rtp/%s", mediaInfo.getWanIp(), mediaInfo.getRtspPort(), streamId));
|
||||
// storager.startPlayback(streamInfoForPlayBack);
|
||||
// }
|
||||
// }
|
||||
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
@@ -268,14 +249,12 @@ public class ZLMHttpHookListener {
|
||||
String app = json.getString("app");
|
||||
String streamId = json.getString("stream");
|
||||
boolean regist = json.getBoolean("regist");
|
||||
// String ssrc = String.format("%10d", Integer.parseInt(streamId, 16)); // ZLM 要求大写且首位补零
|
||||
String ssrc = new DecimalFormat("0000000000").format(Integer.parseInt(streamId, 16));
|
||||
StreamInfo streamInfo = storager.queryPlayBySSRC(ssrc);
|
||||
StreamInfo streamInfo = storager.queryPlayByStreamId(streamId);
|
||||
if ("rtp".equals(app) && !regist ) {
|
||||
if (streamInfo!=null){
|
||||
storager.stopPlay(streamInfo);
|
||||
}else{
|
||||
streamInfo = storager.queryPlaybackBySSRC(ssrc);
|
||||
streamInfo = storager.queryPlaybackByStreamId(streamId);
|
||||
storager.stopPlayback(streamInfo);
|
||||
}
|
||||
}
|
||||
@@ -299,16 +278,14 @@ public class ZLMHttpHookListener {
|
||||
logger.debug("ZLM HOOK on_stream_none_reader API调用,参数:" + json.toString());
|
||||
}
|
||||
|
||||
BigInteger bigint=new BigInteger(json.getString("stream"), 16);
|
||||
int numb=bigint.intValue();
|
||||
String ssrc = String.format("%010d", numb);
|
||||
|
||||
cmder.streamByeCmd(ssrc);
|
||||
StreamInfo streamInfo = storager.queryPlayBySSRC(ssrc);
|
||||
String streamId = json.getString("stream");
|
||||
|
||||
cmder.streamByeCmd(streamId);
|
||||
StreamInfo streamInfo = storager.queryPlayByStreamId(streamId);
|
||||
if (streamInfo!=null){
|
||||
storager.stopPlay(streamInfo);
|
||||
}else{
|
||||
streamInfo = storager.queryPlaybackBySSRC(ssrc);
|
||||
streamInfo = storager.queryPlaybackByStreamId(streamId);
|
||||
storager.stopPlayback(streamInfo);
|
||||
}
|
||||
|
||||
@@ -330,7 +307,30 @@ public class ZLMHttpHookListener {
|
||||
logger.debug("ZLM HOOK on_stream_not_found API调用,参数:" + json.toString());
|
||||
}
|
||||
// TODO Auto-generated method stub
|
||||
|
||||
|
||||
if (autoApplyPlay) {
|
||||
String app = json.getString("app");
|
||||
String streamId = json.getString("stream");
|
||||
if ("rtp".equals(app) && streamId.indexOf("gb_play") > -1) {
|
||||
String[] s = streamId.split("_");
|
||||
if (s.length == 4) {
|
||||
String deviceId = s[2];
|
||||
String channelId = s[3];
|
||||
Device device = storager.queryVideoDevice(deviceId);
|
||||
if (device != null) {
|
||||
UUID uuid = UUID.randomUUID();
|
||||
cmder.playStreamCmd(device, channelId, (JSONObject response) -> {
|
||||
logger.info("收到订阅消息: " + response.toJSONString());
|
||||
playService.onPublishHandlerForPlay(response, deviceId, channelId, uuid.toString());
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
JSONObject ret = new JSONObject();
|
||||
ret.put("code", 0);
|
||||
ret.put("msg", "success");
|
||||
|
||||
@@ -21,8 +21,8 @@ public class ZLMUtils {
|
||||
|
||||
private int currentPort = 0;
|
||||
|
||||
public int getNewRTPPort(String ssrc) {
|
||||
String streamId = String.format("%08x", Integer.parseInt(ssrc)).toUpperCase();
|
||||
public int getNewRTPPort(String streamId) {
|
||||
// String streamId = String.format("%08x", Integer.parseInt(ssrc)).toUpperCase();
|
||||
Map<String, Object> param = new HashMap<>();
|
||||
int newPort = getPortFromUdpPortRange();
|
||||
param.put("port", newPort);
|
||||
@@ -32,7 +32,7 @@ public class ZLMUtils {
|
||||
if (jsonObject != null && jsonObject.getInteger("code") == 0) {
|
||||
return newPort;
|
||||
} else {
|
||||
return getNewRTPPort(ssrc);
|
||||
return getNewRTPPort(streamId);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user