前端使用WebRtc播放rtsp视频流

前言:

项目中需要使用前端播放RTSP视频流,网上找了不少资料,最后决定用WebRtc进行播放。

一、下载WebRtc

下载地址(https://github.com/mpromonet/webrtc-streamer/releases)

在这里插入图片描述
红框内分别为windows版本和Linux版本。

2.windows版本部署

下载windows版本压缩包,解压后如下图
在这里插入图片描述
打开命令窗口(cmd),执行以下命令:

 D:\webrtc-streamer-v0.8.6-dirty-Windows-AMD64-Release\webrtc-streamer.exe -o -H 0.0.0.0:8000

其中 D:\webrtc-streamer-v0.8.6-dirty-Windows-AMD64-Release\webrtc-streamer.exe为绝对路径
-o:无需转码,降低CPU
-H:指定IP及端口号(注意:一般使用0.0.0.0作为指定服务器IP)

在这里插入图片描述
然后在浏览器访问127.0.0.1:8000/webrtcstreamer.html?video=rtsp://192.168.10.112:8557/h264
rtsp:记得修改为自己的rtsp视频流地址

3.Linux版本部署

系统环境都正常的情况安装步骤如下:

1.webrtc-streamer包:webrtc-streamer-v0.7.2-Linux-x86_64-Release.tar.gz
2.拷贝到指定路径下,解压:tar -xvf webrtc-streamer-v0.7.2-Linux-x86_64-Release.tar.gz
3.进入webrtc-streamer-v0.7.2-Linux-x86_64-Release:cd webrtc-streamer-v0.7.2-Linux-x86_64-Release

在这里插入图片描述

4.执行 ./webrtc-streamer -H 0.0.0.0:8000 -o

这里有点需要注意,运行之后如果关闭远程命令工具服务也会停掉,如果需要后台保持运行则需要添加 nohup

nohup ./webrtc-streamer -H 0.0.0.0:8000 -o

这样关闭窗口依然会保持服务状态。

在这里插入图片描述
注意:如果这里报错,可自行百度解决。
然后可以在浏览器去如Windows环境一样进行访问。

二、引入到Vue

将webrtc-streamer下载包html文件夹下webrtcstreamer.js文件和html/libs文件夹下adapter.min.js文件复制到VUE项目public目录下。并在index.html文件里引入这两个js文件。格式如下:

    <script src="<%= BASE_URL %>adapter.min.js"></script>
    <script src="<%= BASE_URL %>webrtcstreamer.js"></script>

在这里插入图片描述

三、编写页面

以下代码可直接复制粘贴,按需修改即可。

<template>
  <div>
    <video id="video" autoplay width="500" height="300"></video>
  </div>
</template>

<script>
export default {
  name: 'index1',
  data() {
    return {
      webRtcServer: null
    }
  },
  mounted() {
    //video:需要绑定的video控件ID
    //127.0.0.1:8000:启动webrtc-streamer的设备IP和端口,默认8000
    this.webRtcServer = new WebRtcStreamer('video', location.protocol + '//127.0.0.1:8000')
    //需要查看的rtsp地址,记得修改rtsp地址
    this.webRtcServer.connect('rtsp://user:password@ip:port/cam/realmonitor?channel=1&subtype=0')
  },
  beforeDestroy() {
    this.webRtcServer.disconnect()
    this.webRtcServer = null
  },
  methods: {

  }
}
</script>

<style scoped></style>

四、运行结果

在这里插入图片描述

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和媒体服务器不太熟悉,可能需要花一些时间学习和实践。此外,不同的媒体服务器和库可能有不同的实现方式和要求,因此请参考它们的官方文档和示例代码以获取详细信息。 希望这些信息对你有所帮助!如有任何问题,请随时提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值