A MSE+Fmp4+websocket+H265播放器

介绍

最近有个需求需要在浏览器上播放网络摄像机的音视频,基本要求就是要低延时

目前最符合低延时要求的是webrtc方案,但由于项目自身原因,暂时无法引入webrtc方案,调研下来,ws+hflv, ws+fmp4是比较好的方案,很多开源播放器也支持播放ws+flv,

从低延时的角度选择,ws+fmp4可能延迟更低一些,毕竟类似flv.js的MSE方案最终也是要把flv封装的视频数据转换成fmp4格式数据喂给MSE。

后来发现开源的支持ws+fmp4的web播放器很少, 要么就是将这个功能放在pro版本收费,要么就是不支持ws+fmp4+h265 .....

最后在各种AI工具的加持下,我这个从未写过前端代码的后端老司机,硬生生的捣鼓出来一个web播放器(功能很单调)
A MSE+fmp4+websocket H2655 WEB 播放器

github地址:https://github.com/machh/machhPlayer

连续跑了四五天,目前看效果还可以,延迟基本上在1秒左右, 这里开源出来,希望大家都可以尝试使用,有问题可以反馈,共同优化,记得点赞+star。

关键特性

  • 低延迟播放:延时1s左右, 通过WebSocket接收fMP4片段,直接追加到MSE的 SourceBuffer中,使用 video.buffered设置currentTime实现从缓存片段的播放。
  • 编解码支持:原生H.264/H.265(fMP4 格式)
  • 技术栈:WebSocket(流传输)、MSE(媒体追加)、HTML5 Video(渲染)
  • 实现了简单的重连/退避机制及内存回收机制,
  • 支持音频H.264/H.265+AAC
  • 对于H.265的解码播放,依赖浏览器MSE原生能力,最新版本的chrome,Edge都可以

截图展示

相关推荐
那就回到过去1 天前
VRRP协议
网络·华为·智能路由器·ensp·vrrp协议·网络hcip
极客小云1 天前
【ComfyUI API 自动化利器:comfyui_xy Python 库使用详解】
网络·python·自动化·comfyui
符哥20081 天前
用Apollo + RxSwift + RxCocoa搭建一套网络请求框架
网络·ios·rxswift
相思难忘成疾1 天前
通向HCIP之路:第四步:边界网关路由协议—BGP(概念、配置、特点、常见问题及其解决方案)
网络·华为·hcip
君陌社区·网络安全防护中心1 天前
基于Mininet模拟SDN环境
网络
Porco.w1 天前
C#与三菱PLC FX5U通信
网络·c#
枷锁—sha1 天前
Burp Suite 抓包全流程与 Xray 联动自动挖洞指南
网络·安全·网络安全
云飞云共享云桌面1 天前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
爱学习的程序媛1 天前
PSTN(公共交换电话网)的起源与发展
网络·信息与通信
roman_日积跬步-终至千里1 天前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络