m3u8 视频流播放:(让后端把rtsp或rtmp转成m3u8视频流)

本文详细介绍了如何将rtsp或rtmp流转化为m3u8视频流并使用video.js进行播放。通过安装和配置video.js、videojs-contrib-hls以及mux.js库,实现在网页中播放m3u8流。文章提供了具体的代码步骤,包括安装、引入、初始化视频以及处理播放事件,同时解决了videojs的报错问题。
摘要由CSDN通过智能技术生成

m3u8是直播流,也称视频流,是做直播视频用的,

m3u8支持谷歌浏览器


网址1:m3u8代码网址:

https://blog.csdn.net/a460550542/article/details/126761626

上面这个网址会报个videojs的错用下面这个网址解决
网址2:解决这个videojs报错

就是把videojs('demo-video', options, function onPlayerReady() 这个函数里面的代码拷贝到m3u8那个网址里面const myPlyer = Videojs('videoPlayer', options, function onPlayerReady () { 这里面:

videojs获取视频播放进度和浏览时长_js获取video时长_test_appletwo的博客-CSDN博客

效果图:



代码步骤:
1. 安装:

版本一定要对:

npm add video.js

npm add videojs-contrib-hls@5.15.0

npm add mux.js@5.7.0

 2. main.js引入:

代码:

import 'video.js/dist/video-js.css' // 引入video.js的css

import hls from 'videojs-contrib-hls' // 播放hls流需要的插件

import Vue from 'vue'

Vue.use(hls)

import './plugins/video.js'   // 引入视频

3.  vue中index页面:
div:


script

 data:

 mounted:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作为一名AI语言模型,我无法进行实战操作。但我可以为您提供相关的思路和技术方案: 1. RTSPRTMP RTSP是实时流传输协议,而RTMP是实时消息传输协议。它们都是用于实时传输音视频流的协议,但是它们的传输方式不同。RTSP是基于TCP的协议,而RTMP是基于TCP或UDP的协议。 要将RTSP流转换为RTMP流,您需要使用一个转换器。其中一个常用的转换器是FFmpeg。FFmpeg是一个开源的多媒体框架,可以处理各种音视频格式,并且支持将RTSP流转换为RTMP流。 以下是使用FFmpeg将RTSP流转换为RTMP流的命令: ffmpeg -i rtsp://xxx.xxx.xxx.xxx:554/xxx -c copy -f flv rtmp://xxx.xxx.xxx.xxx/live/xxx 其中,rtsp://xxx.xxx.xxx.xxx:554/xxx是RTSP流的地址,rtmp://xxx.xxx.xxx.xxx/live/xxx是RTMP流的地址。 2. RTSPM3U8 M3U8是一种基于HTTP的流协议,它是一种多媒体播放列表,用于指定流媒体文件的播放顺序和位置。要将RTSP流转换为M3U8流,您需要使用一个转换器,如FFmpeg。 以下是使用FFmpeg将RTSP流转换为M3U8流的命令: ffmpeg -i rtsp://xxx.xxx.xxx.xxx:554/xxx -c:v libx264 -c:a aac -hls_time 10 -hls_list_size 6 -hls_wrap 10 -start_number 1 /var/www/html/live/xxx.m3u8 其中,rtsp://xxx.xxx.xxx.xxx:554/xxx是RTSP流的地址,/var/www/html/live/xxx.m3u8M3U8流的地址。 3. 集到Java应用程序中 要将上述转换器集到Java应用程序中,您可以使用Java的ProcessBuilder类来执行命令行命令。以下是一个示例代码: String command = "ffmpeg -i rtsp://xxx.xxx.xxx.xxx:554/xxx -c copy -f flv rtmp://xxx.xxx.xxx.xxx/live/xxx"; ProcessBuilder processBuilder = new ProcessBuilder(command.split(" ")); processBuilder.redirectErrorStream(true); Process process = processBuilder.start(); InputStream inputStream = process.getInputStream(); BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream)); String line; while ((line = bufferedReader.readLine()) != null) { System.out.println(line); } process.waitFor(); 要将RTSP转换为M3U8,您可以使用类似的代码,只需更改命令即可。 以上是一个基本的思路和技术方案,具体实现还需要根据您的具体需求进行调整。希望能对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值