0

0

如何在React中使用ffmpeg.wasm将录音的Blob流切分成多个有效的5秒WAV文件?

霞舞

霞舞

发布时间:2025-03-19 11:18:12

|

780人浏览过

|

来源于php中文网

原创

本文探讨了如何在react前端使用ffmpeg.wasm将录音的blob流切分成多个5秒的有效wav文件。直接用javascript处理音频分割,特别是生成正确的wav文件头信息,非常复杂。 因此,我们建议使用ffmpeg.wasm,一个将ffmpeg编译成webassembly的库,来简化这个过程并确保音频文件的完整性。

如何在React中使用ffmpeg.wasm将录音的Blob流切分成多个有效的5秒WAV文件?

问题: 使用react-mic录制音频后,尝试将Blob流切分成多个5秒WAV文件时,只有第一个文件可播放,其余文件损坏。手动添加WAV头信息也无法解决问题。

解决方案:利用ffmpeg.wasm

ffmpeg.wasm提供了一种在浏览器中高效处理音频和视频的方案。它能可靠地分割音频,并自动处理WAV文件头信息,避免手动操作带来的错误。

步骤:

Cutout.Pro
Cutout.Pro

AI驱动的视觉设计平台

下载
  1. 引入ffmpeg.wasm: 确保已正确安装并引入@ffmpeg/ffmpeg库。

  2. 分割音频函数: 以下是一个使用ffmpeg.wasm分割音频的示例函数:

import { createFFmpeg, fetchFile } from '@ffmpeg/ffmpeg';

async function splitAudio(blob, segmentDuration) {
    const ffmpeg = createFFmpeg({ log: true });
    await ffmpeg.load();

    const buffer = await blob.arrayBuffer();
    ffmpeg.FS('writeFile', 'input.wav', new Uint8Array(buffer));

    await ffmpeg.run(
        '-i', 'input.wav',
        '-f', 'segment',
        '-segment_time', segmentDuration,
        '-c', 'copy',
        'output%03d.wav' // 输出文件命名:output001.wav, output002.wav...
    );

    const files = ffmpeg.FS('readdir', '.').filter(file => file.startsWith('output') && file.endsWith('.wav'));
    return files.map(file => {
        const data = ffmpeg.FS('readFile', file);
        return new Blob([data.buffer], { type: 'audio/wav' });
    });
}
  1. React组件集成: 在你的React组件中,调用splitAudio函数处理录音的Blob数据。 以下是一个简化的示例,假设你已拥有react-mic的录音功能:
import React, { useRef, useState } from 'react';
import { ReactMic } from 'react-mic'; // 假设你已安装 react-mic

// ... 其他代码 ...

const handleSave = async () => {
    const blobs = await splitAudio(recordedBlob, '00:00:05'); // 5秒分割
    blobs.forEach((blob, index) => {
        const url = URL.createObjectURL(blob);
        const a = document.createElement('a');
        a.href = url;
        a.download = `recording_${index + 1}.wav`;
        a.click();
        URL.revokeObjectURL(url);
    });
};

// ... 其他代码 ...



关键改进:

  • 避免手动处理WAV头: ffmpeg.wasm自动处理WAV文件头,避免了手动操作导致的错误。
  • 更可靠的分割: 使用ffmpeg的-segment_time参数进行精确的音频分割。
  • 简化代码: 避免了复杂的Blob手动分割和WAV头信息处理。

记住在使用前安装@ffmpeg/ffmpegnpm install @ffmpeg/ffmpegyarn add @ffmpeg/ffmpeg。 这个方法提供了更可靠、更简洁的音频分割方案,避免了之前手动处理带来的问题。 请根据你的实际项目代码进行调整。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

12

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

4

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

18

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

19

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

3

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.29

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
如何进行WebSocket调试
如何进行WebSocket调试

共1课时 | 0.1万人学习

TypeScript全面解读课程
TypeScript全面解读课程

共26课时 | 5.1万人学习

前端工程化(ES6模块化和webpack打包)
前端工程化(ES6模块化和webpack打包)

共24课时 | 5.1万人学习

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

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