WebRTC实现rtsp流在浏览器中播放

一般诸如海康威视,大华等监控视频流都是推送的rtsp或rtmp流,这些都是无法在浏览器中直接播放的。因此出现了以下几种方法实现在浏览器端播放。

处理该问题的主流方法大概分为以下几种

PS(由于浏览器的更迭以及Flash不在被支持,所以依赖IE和Flash的方法如使用IE浏览器配合VLC插件,通过video.js配合Flash实现网页播放此处不作介绍)

  1. 通过Nginx+ffmpeg+nginx-http-flv-module模块将rtsp流转为flv格式使用flv.js直接播放
  2. 通过webrtc-streamer将rtsp转为WebRTC流播放
  3. 其他一些插件

通过WebRTC实现播放

  • webrtc-streamer插件开源地址:https://github.com/mpromonet/webrtc-streamer
  • 通过git clone命令下载对应系统webrtc
  • 解压后进入文件目录下,通过CMD打开,输入webrtc-streamer.exe -H 0.0.0.0:9001启动服务(可以指定ip地址和端口号,远程访问注意防火墙)
  • 启动成功后可输入以下地址访问页面预览,注意,如果绑定的不是0.0.0.0请输入对应ip
    http://127.0.0.1:9001/webrtcstreamer.html?video=你的rtsp流地址
  • 如果无法查看视频(确保rtsp流地址正确的情况下,不确定可以先用vlc访问一下),可能是权限问题,尝试用管理员身份打开CMD

通过代码实现

<html>
<head>
<script src="js/adapter.min.js" ></script>
<script src="js/webrtcstreamer.js" ></script>
<script>
    var webRtcServer= null;
    window.onload= function() { 
    webRtcServer= new WebRtcStreamer("video","http://ip地址:9001");
	webRtcServer.connect("rtsp地址");
    }
    window.onbeforeunload = function() { webRtcServer.disconnect(); }
</script>
</head>
<body class="body">
<video id="video" autoplay muted ></video>
</body>
<style>
.body{
  width:100%;
  height:100%;
  padding:0;
  margin:0;
}
#video{
  padding:0;
  width:720px;
  height:400px;
}
</style>
</html>

  • 5
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
WebRTC(Web实时通信)是一种实时通信技术,主要用于在浏览器之间进行音视频通信。然而,WebRTC并不直接支持RTSP(实时流传输协议)。要在浏览器播放RTSP视频流,你需要经过一些额外的步骤。 一种常见的方法是使用服务器端转换将RTSP流转换为WebRTC流。这可以通过使用媒体服务器(如Kurento、Janus或GStreamer)来实现。首先,你需要将RTSP流导入到媒体服务器,然后使用WebRTC将其传送到浏览器。可以通过使用JavaScript库(如mediasoup、SimpleWebRTCwebrtc.js)来实现WebRTC的客户端部分。 以下是一个大致的步骤概述: 1. 设置媒体服务器:选择一个适合你需求的媒体服务器,并按照其文档进行安装和配置。 2. 导入RTSP流:使用媒体服务器提供的API或命令行界面,将RTSP流导入到媒体服务器。这可能涉及到指定RTSP流的URL、设置解码参数等。 3. 设置WebRTC客户端:在浏览器创建一个WebRTC客户端,以接收来自媒体服务器的流并播放。你可以使用JavaScript库来简化这个过程。 4. 连接与播放:通过WebRTC客户端与媒体服务器建立连接,并将媒体流传送到浏览器进行播放。你可以根据需要自定义播放界面和控制逻辑。 需要注意的是,这个过程涉及到一些复杂的技术和配置。如果你对WebRTC和媒体服务器不太熟悉,可能需要花一些时间学习和实践。此外,不同的媒体服务器和库可能有不同的实现方式和要求,因此请参考它们的官方文档和示例代码以获取详细信息。 希望这些信息对你有所帮助!如有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值