0

0

html5怎么播放rtsp流_html5播放rtsp流实现思路【步骤】

絕刀狂花

絕刀狂花

发布时间:2026-01-28 17:05:31

|

922人浏览过

|

来源于php中文网

原创

HTML5原生不支持RTSP,需服务端转协议;推荐FFmpeg+Nginx-rtmp转HTTP-FLV,延迟1–3秒,兼容性好,前端用flv.js播放;HLS延迟高(≥10秒),WebRTC延迟最低但部署复杂。

html5怎么播放rtsp流_html5播放rtsp流实现思路【步骤】

HTML5 原生不支持 RTSP,必须转协议

浏览器(包括所有 HTML5 实现)从底层就不支持 RTSP 协议。你直接在 标签里写 src="rtsp://..." 一定失败,控制台会报 MediaError.MEDIA_ERR_SRC_NOT_SUPPORTED 或直接静默无响应。

根本原因是:RTSP 是控制协议,不定义媒体封装格式;而 HTML5 只接受 HTTP(S) 传输的 MP4/WebM/FLV(需配合 MSE)等可随机访问、有明确时间戳和索引的格式。

  • RTSP 流通常来自 IPC 摄像头,原始输出是 H.264/H.265 + AAC/G.711 的裸流或 RTP 包
  • 浏览器无法解析 RTP 包,也不能处理 RTSP 的 SETUP/PLAY 交互
  • 所以必须在服务端做协议转换:把 RTSP → HTTP-FLV / HLS / WebRTC / MSE-compatible fragmented MP4

推荐方案:用 FFmpeg + Nginx-rtmp-module 转成 HTTP-FLV

这是目前延迟最低(1–3 秒)、兼容性最好、前端最省事的方案。HTTP-FLV 可通过 fetch + MediaSource + flv.js 播放,无需后端信令或 WebSocket。

关键步骤:

立即学习前端免费学习笔记(深入)”;

PNG Maker
PNG Maker

利用 PNG Maker AI 将文本转换为 PNG 图像。

下载
  • 安装 ffmpeg,运行命令拉流并推到本地 Nginx-rtmp 服务器:
    ffmpeg -i "rtsp://192.168.1.100:554/stream" -c copy -f flv rtmp://127.0.0.1:1935/live/stream1
  • Nginx 配置启用 rtmp 模块,并开启 http_flv
    application live { live on; http_flv on; }
  • 前端用 flv.js 加载:
    const flvPlayer = flvjs.createPlayer({ type: 'flv', isLive: true, url: 'http://localhost:8080/live/stream1.flv' });
  • 注意:flv.js 不支持 H.265,若摄像头输出 H.265,必须加 -c:v libx264 转码

替代方案对比:HLS vs WebRTC vs MSE-raw

选型要看延迟容忍度和终端覆盖范围:

  • HLS.m3u8):iOS/macOS 原生支持,但延迟高(通常 ≥10 秒),且需要切片器(如 ffmpeg -f hlsnginx-http-flv-module 的 HLS 模块)。Safari 不能用 MSE 加载 HLS,只能靠原生
  • WebRTC:延迟最低(RTCPeerConnection,服务端需支持 WebRTC 接入(如 mediasoupJanus)。对 RTSP 源需额外做 RTP → WebRTC 封装
  • MSE + 自定义解复用:用 ffmpeg.wasm 在浏览器内转码 RTSP?不可行——RTSP 需要 TCP/RTP socket,WebAssembly 无法直接建 RTP 连接;纯 JS 解析 RTP 包性能差且不实用

容易被忽略的坑:跨域、CORS、HTTPS 混合内容、时间戳对齐

即使协议转对了,播放仍可能失败,常见卡点:

  • flv.js 加载时浏览器报 Cross-Origin Read Blocking (CORB)?确保 Nginx 返回 Access-Control-Allow-Origin: *,且 flv.jswithCredentials 设为 false(默认)
  • 页面是 https://,但 FLV 地址是 http://?现代浏览器禁止混合内容,必须全站 HTTPS,或用自签名证书跑本地 https://localhost
  • 画面卡顿/音画不同步?检查 RTSP 源的时间戳(PTS/DTS)是否连续;ffmpeg 转发时加 -fflags +genpts 强制生成 PTS
  • 某些海康/NVR 设备 RTSP URL 含特殊参数(如 channel=1&subtype=0),URL 必须完整编码,否则 ffmpeg 解析失败

真正麻烦的从来不是“怎么播”,而是“怎么让每一帧都按时、按序、不丢包地送进 MediaSource”。协议转换链路上任意一环的时间戳错位或缓冲区溢出,都会导致花屏或卡死——这点在低码率移动网络下尤其明显。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

233

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

502

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

500

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

338

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3517

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

30

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

34

2026.01.13

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

AngularJS教程
AngularJS教程

共24课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 24.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号