音频视频处理:前端直播流播放 flv

文章目录

    • 需求
    • 分析
      • [方案 1:使用 Video.js + HLS 插件(播放 HLS 流,兼容性最好)](#方案 1:使用 Video.js + HLS 插件(播放 HLS 流,兼容性最好))
      • [方案 2:使用 Flv.js(播放 FLV 流,低延迟)](#方案 2:使用 Flv.js(播放 FLV 流,低延迟))
      • [方案 2 优化:](#方案 2 优化:)
      • [方案 3:使用 WebRTC 播放器(超低延迟,适合实时场景)](#方案 3:使用 WebRTC 播放器(超低延迟,适合实时场景))

需求

上一个文章中写到将直播的流转换成前端可播放的格式,使用的是 ffmpeg 的方式进行的:海康监控直播流播放处理

现在如果这一步转换流的方式放在服务端,我们客户端不需要这么处理的话,就需要用前端来播放转换后的流(两种主流播放器方案)

分析

方案 1:使用 Video.js + HLS 插件(播放 HLS 流,兼容性最好)

Video.js 是开源播放器,配合 videojs-hls-plugin 可播放 HLS(m3u8)流,支持所有现代浏览器

javascript 复制代码
<template>
  <div class="player-container">
    <video id="player" class="video-js vjs-big-play-centered" controls preload="auto"></video>
  </div>
</template>

<script setup lang="ts">
import { onMounted } from 'vue';
import VideoJs from 'video.js';
import 'video.js/dist/video-js.css';
import Hls from 'videojs-contrib-hls'; // 引入HLS插件

// 注册HLS插件
VideoJs.registerPlugin('hls', Hls);

onMounted(() => {
  // 初始化播放器,播放转换后的HLS流(替换为你的服务器地址)
  const player = VideoJs('player', {
    autoplay: true,
    muted: true, // 自动播放需要静音(浏览器策略)
    loop: false,
    controls: true,
    fluid: true, // 自适应宽高
    sources: [{
      src: 'http://你的服务器IP/live/stream.m3u8', // HLS流地址
      type: 'application/x-mpegURL' // HLS的MIME类型
    }]
  });

  // 销毁播放器(组件卸载时)
  const handleUnmount = () => {
    if (player) {
      player.dispose();
    }
  };
  window.addEventListener('beforeunload', handleUnmount);
});
</script>

<style scoped>
.player-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}
</style>

安装依赖:

javascript 复制代码
npm install video.js videojs-contrib-hls --save

方案 2:使用 Flv.js(播放 FLV 流,低延迟)

Flv.js 是 B 站开源的播放器,支持播放 FLV 流,延迟比 HLS 更低。

javascript 复制代码
<template>
  <div class="player-container">
    <video id="player" controls preload="auto" muted autoplay></video>
  </div>
</template>

<script setup lang="ts">
import { onMounted } from 'vue';
import flvjs from 'flv.js';

onMounted(() => {
  // 检查浏览器是否支持
  if (flvjs.isSupported()) {
    const videoElement = document.getElementById('player') as HTMLVideoElement;
    const flvPlayer = flvjs.createPlayer({
      type: 'flv',
      url: 'http://你的服务器IP/live/stream.flv' // FLV流地址(需Nginx发布)
      // 若为RTMP流,type改为'rtmp',url改为'rtmp://你的服务器IP:1935/live/stream'
    });
    flvPlayer.attachMediaElement(videoElement);
    flvPlayer.load();
    flvPlayer.play();

    // 销毁播放器
    const handleUnmount = () => {
      flvPlayer.destroy();
    };
    window.addEventListener('beforeunload', handleUnmount);
  }
});
</script>

<style scoped>
.player-container {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
}
</style>

安装依赖

javascript 复制代码
npm install flv.js --save

方案 2 优化:

使用 Flv.js 时,会出现更新流时页面再次初始化播放会报错:Failed to execute 'appendBuffer' on 'SourceBuffer': This SourceBuffer has been removed from the parent media source.

javascript 复制代码
const mixStreamUrl = (Url) => {
  const dom = document.getElementById('player') as HTMLVideoElement
  if (flvjs.isSupported()) {
    // 销毁现有播放器实例
    if (flvPlayer) {
      flvPlayer.destroy()
      flvPlayer = null
    }
    // 创建新的播放器实例
    flvPlayer = flvjs.createPlayer({
      type: 'flv',
      url: Url
      // 若为RTMP流,type改为'rtmp',url改为'rtmp://你的服务器IP:1935/live/stream'
    })
    flvPlayer.attachMediaElement(dom)
    flvPlayer.load()
    flvPlayer.muted = false
    flvPlayer.play()
  }
}

方案 3:使用 WebRTC 播放器(超低延迟,适合实时场景)

若转换为 WebRTC 流,可使用 simple-peer 或原生 WebRTC API 播放

javascript 复制代码
// 原生WebRTC播放(需配合SRS等服务器的WebRTC推流)
const pc = new RTCPeerConnection({
  iceServers: [{ urls: 'stun:stun.l.google.com:19302' }]
});

// 接收视频流
pc.ontrack = (e) => {
  const videoElement = document.getElementById('player');
  videoElement.srcObject = e.streams[0];
};

// 发起请求(具体信令需配合服务器,如SRS的WebRTC信令)
fetch('http://你的服务器IP/rtc/v1/play/', {
  method: 'POST',
  body: JSON.stringify({
    api: 'play',
    streamurl: 'webrtc://你的服务器IP/live/stream'
  })
}).then(res => res.json()).then(data => {
  pc.setRemoteDescription(new RTCSessionDescription(data.sdp));
  pc.createAnswer().then(answer => {
    pc.setLocalDescription(answer);
    // 发送answer到服务器(信令交互)
  });
});
相关推荐
Byron070717 小时前
Vue 中使用 Tiptap 富文本编辑器的完整指南
前端·javascript·vue.js
css趣多多17 小时前
地图快速上手
前端
zhengfei61118 小时前
面向攻击性安全专业人员的一体化浏览器扩展程序[特殊字符]
前端·chrome·safari
码丁_11718 小时前
为什么前端需要做优化?
前端
Mr Xu_18 小时前
告别硬编码:前端项目中配置驱动的实战优化指南
前端·javascript·数据结构
Byron070719 小时前
从 0 到 1 搭建 Vue 前端工程化体系:提效、提质、降本实战落地
前端·javascript·vue.js
哆啦code梦19 小时前
前端存储三剑客:localStorage、sessionStorage与Cookie解析
前端·前端存储
徐小夕@趣谈前端19 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
Data_Journal19 小时前
如何使用 Python 解析 JSON 数据
大数据·开发语言·前端·数据库·人工智能·php
德育处主任Pro19 小时前
纯前端网格路径规划:PathFinding.js的使用方法
开发语言·前端·javascript