当前位置: 首页 > news >正文

构建直播平台大体的流程

✅ 直播流程完整链路(基于 SRS + OBS + 前后端)


🧍‍♂️ 用户操作流程:

  1. 用户登录系统(前端)

    • 系统中校验用户身份(JWT 等)

    • 后端可能校验权限,比如“是否有开播资格”

  2. 用户点击“我要开播”

    • 前端调用后端接口,例如:POST /api/live/apply

    • 后端生成并返回推流地址 + 推流码(Key)

      • 示例返回:

        { "livePushUrl": "rtmp://your-srs-ip/live/room123", "livePushSecret": "abc123" // 有些平台把推流码单独拆开 }

  3. 前端展示推流地址 + 推流码

    • 前端展示给用户复制:

      推流地址: rtmp://your-srs-ip/live 推流码(StreamName): room123?token=abc123

  4. 用户打开 OBS

    • 进入设置 > 推流

      • 服务:自定义

      • 推流地址:rtmp://your-srs-ip/live

      • 串流密钥(推流码):room123?token=abc123

    • 开始推流


📡 技术流程图(你可以参考这个思维路径):

[用户点击我要开播]↓
[前端调用后端接口生成推流地址]↓
[后端生成 RTMP 地址和推流密钥]↓
[前端展示推流地址+密钥]↓
[用户复制地址/密钥到 OBS 开始推流]↓
[OBS 推流至 SRS 流媒体服务器]↓
[SRS 接收 RTMP 流并转为 FLV/HLS 等格式]↓
[用户/观众端 前端播放器(flv.js)拉取播放地址,播放视频流]

🎬 观众端播放流程:

  1. 前端页面通过 flv.jsvideo.js 拉取播放地址,比如:

    http://your-srs-ip/live/room123.flv

  2. 播放器组件 flv.js 将流绑定在 <video> 标签上

  3. 用户看到直播画面


🧠 小贴士(进阶要点)

环节补充说明
推流地址一般是 rtmp://ip/live/房间号,后面可附加签名参数防盗链
推流码(stream key)可作为 URL 的查询参数,便于权限控制
播放地址一般用 .flv.m3u8,给前端播放器使用
OBS只要填写好推流地址和 key,就能推流成功
SRS可配置是否开启 flv/hls/webrtc 输出,是否验证签名等

前端组件页面

<template><div class="live-play-wrapper"><div class="player-header"><h2>直播播放</h2><p v-if="!url" class="error-text">⚠️ 当前无有效直播地址</p></div><div class="player-container" v-if="url"><videoref="videoElement"id="videoElement"controlsautoplaymutedwidth="100%"height="100%"class="video-player"></video></div><div v-else class="no-url-placeholder"><p>请等待推流或联系管理员开启直播</p></div></div>
</template><script>
import flvjs from "flv.js";export default {name: "LivePlay",props: {url: {type: String,required: false,default: "",},},data() {return {flvPlayer: null,};},watch: {url(newUrl) {console.log("播放地址变化:", newUrl);this.destroyPlayer();if (newUrl) {this.initPlayer(newUrl);}},},mounted() {if (this.url) {this.initPlayer(this.url);}},beforeDestroy() {this.destroyPlayer();},methods: {initPlayer(playUrl) {if (flvjs.isSupported()) {const video = this.$refs.videoElement;this.flvPlayer = flvjs.createPlayer({type: "flv",url: playUrl,isLive: true,});this.flvPlayer.attachMediaElement(video);this.flvPlayer.load();this.flvPlayer.play().catch((err) => {console.error("播放失败", err);});// 监听播放错误this.flvPlayer.on(flvjs.Events.ERROR, (errType, errDetail) => {console.error("FLV 播放出错", errType, errDetail);// 可选:自动重连// setTimeout(() => this.initPlayer(playUrl), 3000);});} else {console.warn("浏览器不支持 flv.js 播放");}},destroyPlayer() {if (this.flvPlayer) {this.flvPlayer.destroy();this.flvPlayer = null;}},},
};
</script><style scoped>
.live-play-wrapper {width: 100%;max-width: 960px;margin: 0 auto;padding: 20px;
}
.player-header {text-align: center;margin-bottom: 15px;
}
.error-text {color: red;font-weight: bold;
}
.player-container {border: 2px solid #ccc;border-radius: 10px;overflow: hidden;background: #000;height: 540px;
}
.video-player {width: 100%;height: 100%;background-color: #000;
}
.no-url-placeholder {text-align: center;font-size: 16px;color: #999;margin-top: 30px;
}
</style>

使用组件标签

<LivePlay :url="'http://your-srs-server/live/room123.flv'" />

http://www.dtcms.com/a/286271.html

相关文章:

  • gcc 源码阅读---编译器后端实现的关键数据结构
  • DOM笔记
  • 什么是KL散度
  • Android-EDLA【CTS】CtsInputMethodTestCases存在fail
  • 4G模块 A7680发送中文短信到手机
  • 高精度减法模版和分析(C++版本)
  • 嵌入式八股(持续更新)
  • 【算法训练营Day14】二叉树part4
  • windows终端美化(原生配置+Oh My Posh主题美化)
  • 客诉:危机到信任的重建
  • Flutter 应用如何设计通知服务
  • Flutter——Android原生View是如何通过Flutter进行加载
  • 2025年Flutter开发主流技术栈
  • Flutter 多语言(国际化)入门教程
  • 企业如何让内部视频仅限公司官网或指定域名播放?
  • 低代码开发实践博客
  • C++语法 匿名对象 与 命名对象 的详细区分
  • IDEA 中 Maven 配置:当前项目与新项目的统一设置方法
  • 【Docker基础】Docker Compose核心配置文件深度解析:从YAML语法到高级配置
  • 【数据结构】栈的深入解析--用C语言实现
  • Linux 环境下 NNG 通讯库:在嵌入式设备上应用
  • [2025CVPR-目标检测方向] CorrBEV:多视图3D物体检测
  • Docker 与 GPU 训练
  • 排序【各种题型+对应LeetCode习题练习】
  • 线程控制:互斥与同步
  • IDEA高效开发:Database Navigator插件安装与核心使用指南
  • Python趣味算法:抓交通肇事犯(车牌号谜题解析)
  • nginx定制http头信息
  • 腾讯云云服务器深度介绍
  • 面试150 克隆图