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

构建直播平台大体的流程

✅ 直播流程完整链路(基于 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.xdnf.cn/news/15794.html

相关文章:

  • 后端参数校验
  • Docker部署前后端分离项目——多项目共享环境部署
  • AI进入自动驾驶时代:OpenAI发布革命性ChatGPT Agent
  • 关于在VScode中使用git的一些步骤常用命令及其常见问题:
  • 从 C# 到 Python:6 天极速入门(第二天)
  • 【PTA数据结构 | C语言版】二叉堆的快速建堆操作
  • 数据结构:顺序表和链表
  • LeetCode1047删除字符串中的所有相邻重复项
  • Jenkins+Docker+Git实现自动化CI/CD
  • 谈进程间通信
  • Python 模块化编程全解析:模块、包与第三方库管理指南
  • [Raspberry Pi]如何將無頭虛擬顯示器服務(headless display)建置在樹莓派的Ubuntu桌面作業系統中?
  • SGMD辛几何模态分解 直接替换Excel运行包含频谱图相关系数图 Matlab语言!
  • 微信小程序列表数据上拉加载,下拉刷新
  • 7.事务操作
  • 手机兼容测试服务提供商对比分析:如何选择最合适的测试平台
  • 分层图最短路径算法详解
  • Spring整合MyBatis详解
  • 通过轮询方式使用LoRa DTU有什么缺点?
  • Trae IDE:打造完美Java开发环境的实战指南
  • JUnit5 实操
  • 系统设计时平衡超时时间与多因素认证(MFA)带来的用户体验下降
  • istio如何自定义重试状态码
  • 【Jmeter】报错:An error occured:Unknown arg
  • FreeRTOS—中断管理
  • 基于pytorch深度学习笔记:2.VGGNet介绍
  • 腾讯会议本地录屏转存失败解决办法
  • 支付宝小程序 MAU(月活跃用户数)是衡量用户粘性与生态影响力的核心指标
  • 【深度学习新浪潮】AI在finTech领域有哪些值得关注的进展?
  • 专业职业评估工具,多维度数据分析