0

0

HTML5怎么检测视频编码格式_获取视频编码信息的JS实现方式【教程】

看不見的法師

看不見的法師

发布时间:2026-01-03 19:55:02

|

1016人浏览过

|

来源于php中文网

原创

MediaSource.isTypeSupported() 是验证浏览器是否支持特定编码的最轻量可靠方法,需传入完整 MIME + 编码字符串(如 "video/mp4; codecs=\"avc1.64001f\""),返回 true 仅表示“可能支持”,实际播放还受硬件、驱动等限制。

html5怎么检测视频编码格式_获取视频编码信息的js实现方式【教程】

MediaSource.isTypeSupported() 判断编码是否被浏览器支持

浏览器本身不提供直接读取视频文件编码格式(如 avc1.64001fmp4a.40.2)的 API,但可以通过 MediaSource.isTypeSupported() 检查某类 MIME 类型 + 编码字符串是否能被当前环境解码。这是最轻量、最可靠的第一步验证。

  • 它只接受完整 MIME + 编码字符串,例如 "video/mp4; codecs=\"avc1.64001f\"""audio/mp4; codecs=\"mp4a.40.2\""
  • 返回 true 仅表示“可能支持”,不代表该视频一定能播——实际解码还依赖硬件、驱动、系统限制
  • 对 HLS 或 MSE 动态加载场景,必须在创建 MediaSource 实例前调用,且不能跨源调用(CORS 会拦截)

从 MP4 文件头解析 avcCesds Box 获取编码细节

如果已知视频是 MP4(或 MOV、M4A),可借助 FileReader 读取前几 KB,手动解析容器中的编码描述信息。MP4 的视频编码信息藏在 avcC box(H.264/AVC)或 hvcC box(H.265/HEVC)里;音频则在 esds(AAC)或 dac3(AC3)中。

  • 需按字节读取,跳过 ftypmoov 等 header,定位到具体 box 起始位置
  • avcC 中第 5 字节是 profile_idc,后续字节含 level、sps/pps 原始数据,可推导出标准编码字符串如 "avc1.64001f"
  • 前端解析有精度限制:无法区分 Baseline/High Profile 下的某些子集,也难处理 fragmented MP4
const parseAvccBox = (bytes) => {
  // 假设 bytes 是 Uint8Array,已定位到 avcC box payload 起始
  const profile = bytes[1];
  const level = bytes[3];
  const naluLengthSize = (bytes[4] & 3) + 1; // 1, 2 or 4
  return `avc1.${profile.toString(16).padStart(2, '0')}${level.toString(16).padStart(2, '0')}00`;
};

canPlayType() 辅助推测主编码类型

HTMLMediaElement.canPlayType() 不返回具体编码,但能快速排除明显不兼容的格式,比如 video.canPlayType("video/webm; codecs=\"vp9\"") 返回 "probably" 就说明 VP9 解码链大概率就绪。

  • 它对 codecs 参数敏感,引号必须存在,空格不能省略,大小写部分影响结果(如 "avc1.64001f""AVC1.64001F" 可能不同)
  • 返回值只有 """maybe""probably",没有中间状态,也不反映当前 video 元素加载的是什么文件
  • 适合做播放前快速兜底判断,不适合用于分析已加载视频的实际编码

服务端解析仍是获取准确编码信息的首选方案

前端 JS 无法可靠提取完整编码参数(如 H.264 的 CABAC 开关、色度采样、bit depth),也无法识别 DRM 加密流或自定义封装格式。真正需要精确信息(比如转码决策、CDN 分发策略、合规性检查),必须由服务端完成解析。

百度智能云·曦灵
百度智能云·曦灵

百度旗下的AI数字人平台

下载

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

  • 推荐工具:FFmpeg(ffprobe -v quiet -show_entries stream=codec_name,width,height,profile,level -of json
  • 前端可发起一次轻量请求,传入视频 URL,后端返回结构化编码信息 JSON
  • 注意避免跨域问题:后端需正确设置 Access-Control-Allow-Origin,且视频资源本身也要允许跨域(CrossOrigin="anonymous"

编码字符串里的每个数字都有含义,比如 avc1.64001f 中的 1f 是 level_idc(31 → Level 3.1),但浏览器不会告诉你这个映射关系——靠 JS 硬猜容易错,尤其遇到新编码如 AV1 的 av01.0.05M.08,字段含义完全不同。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

404

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

530

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

308

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html5动画制作有哪些制作方法
html5动画制作有哪些制作方法

html5动画制作方法有使用CSS3动画、使用JavaScript动画库、使用HTML5 Canvas等。想了解更多html5动画制作方法相关内容,可以阅读本专题下面的文章。

500

2023.10.23

HTML与HTML5的区别
HTML与HTML5的区别

HTML与HTML5的区别:1、html5支持矢量图形,html本身不支持;2、html5中可临时存储数据,html不行;3、html5新增了许多控件;4、html本身不支持音频和视频,html5支持;5、html无法处理不准确的语法,html5能够处理等等。想了解更多HTML与HTML5的相关内容,可以阅读本专题下面的文章。

419

2024.03.06

html5从入门到精通汇总
html5从入门到精通汇总

想系统掌握HTML5开发?本合集精选全网优质学习资源,涵盖免费教程、实战项目、视频课程与权威电子书,从基础语法到高级特性(Canvas、本地存储、响应式布局等)一应俱全,适合零基础小白到进阶开发者,助你高效入门并精通HTML5前端开发。

5

2025.12.30

html5新老标签汇总
html5新老标签汇总

HTML5在2026年持续优化网页语义化与交互体验,不仅引入了如<header>、<nav>、<article>、<section>、<aside>、<footer>等结构化标签,还新增了<video>、<audio>、<canvas>、<figure>、<time>、<mark>等增强多媒体与

10

2025.12.30

python设置中文版教程合集
python设置中文版教程合集

本专题整合了python改成中文版相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.05

热门下载

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

精品课程

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

共46课时 | 2.8万人学习

AngularJS教程
AngularJS教程

共24课时 | 2.3万人学习

CSS教程
CSS教程

共754课时 | 17.7万人学习

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

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