B站缓存视频M4S合并MP4(js + ffmpeg )

文章目录

      • [B站缓存视频转MP4(js + ffmpeg )](#B站缓存视频转MP4(js + ffmpeg ))
      • 1、说明
      • 2、ffmpeg
        • [2.1 下载地址](#2.1 下载地址)
        • [2.2 配置环境变量](#2.2 配置环境变量)
        • [2.3 测试](#2.3 测试)
        • [2.4 转换MP4命令](#2.4 转换MP4命令)
      • 3、处理程序

B站缓存视频转MP4(js + ffmpeg )

注意:这样的方式只用于个人之间不同设备的离线观看。请勿用于商业用途!!

程序我放在了gitee,https://gitee.com/Little_Code_Farmer/m4s_to_mp4.git,可跳转参考

1、说明

目前b站下载的视频并不是 mp4 格式的,而是 m4s (两个 m4s 文件,分别代表音频文件和视频文件);需要用 ffmpeg 将两个文件合并成一个 mp4 文件

txt 复制代码
Android\data\tv.danmaku.bilibilihd\download
内部一个目录代表一个缓存项
一个缓存项内部可能会有多个目录代表视频不止一个(多集);否则就是一个视频

- 视频id
|-- 某一集
|---- 某一集的相关信息 json (一般为entry文件)
|---- 某一集视频的具体音频内容 目录(内部有存放 m4s 文件:video.m4s、audio.m4s )
  • 两个缓存项:
  • 多集:id为47231894的视频有两集

2、ffmpeg

2.1 下载地址

https://www.onlinedown.net/soft/616370.htm#downBox

下载后先解压到特定目录(譬如:D:\ffmpeg\bin

2.2 配置环境变量

打开环境变量(用户变量和系统变量都可以;此处修改的是用户变量)。新建变量,定位至 bin 目录(PS. 可以不配置环境变量,后续执行该命令时用绝对路径就可以

2.3 测试
bash 复制代码
# 已配置环境变量:打开命令行窗口,输入  
ffmpeg -version 

# 未配置环境变量:需要先定位到目录(D:\ffmpeg\bin);再执行对应的exe文件
D:\ffmpeg\bin\ffmpeg.exe -version
2.4 转换MP4命令
bash 复制代码
# ffmpeg [-i m4s文件地址 -可使用多次] -codec copy "生成的MP4名称" 
ffmpeg -i ./47231894/4712384/video.m4s -i ./47231894/4712384/audio.m4s -codec copy ./result.mp4

3、处理程序

PS. 可使用别的语言,java,py等等(作用都是获取 ffmpeg 的参数,拼接命令),实际就是通过DOS多次执行 ffmpeg 命令

3.1 获取所有缓存项

3.2 遍历缓存项,读取 entry.json 文件,拿到 title 属性,以该名称创建目录;内部存放视频

3.3 缓存项是多集:以 entry.json 文件内部的 page_data.part 属性为MP4文件名称

3.4 缓存项是单集:以 entry.json 文件内部的 title 属性为 MP4 文件名称

3.5 拼接ffmpeg参数,音频、视频地址,输出的文件地址;

相关推荐
拉不动的猪6 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
大金乄8 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
Lee川10 小时前
解锁 JavaScript 的灵魂:深入浅出原型与原型链
javascript·面试
swipe11 小时前
从原理到手写:彻底吃透 call / apply / bind 与 arguments 的底层逻辑
前端·javascript·面试
Lee川13 小时前
探索JavaScript的秘密令牌:独一无二的`Symbol`数据类型
javascript·面试
Lee川13 小时前
深入浅出JavaScript事件机制:从捕获冒泡到事件委托
前端·javascript
光影少年13 小时前
async/await和Promise的区别?
前端·javascript·掘金·金石计划
codingWhat13 小时前
如何实现一个「万能」的通用打印组件?
前端·javascript·vue.js
前端Hardy15 小时前
别再无脑用 `JSON.parse()` 了!这个安全漏洞你可能每天都在触发
前端·javascript·vue.js
前端Hardy15 小时前
别再让 `console.log` 上线了!它正在悄悄拖垮你的生产系统
前端·javascript·vue.js