当前位置: 首页 > news >正文

Vue中字节流格式的 Base64编码转换为 Blob 对象保存成wav的音频文件

1、安装Vue组件FileSaver.js

npm install file-saver

2、使用

import { saveAs } from 'file-saver';const saveAudioToFile = (text) => {API({url: `/api/xxx/xxx?content=${text}`,method: "post",}).then(res => {let obj = res.data;if (obj.code === 200) {const base64Audio = obj.data.audio;const byteCharacters = atob(base64Audio);const byteArrays = [];for (let offset = 0; offset < byteCharacters.length; offset += 512) {const slice = byteCharacters.slice(offset, offset + 512);const byteNumbers = new Array(slice.length);for (let i = 0; i < slice.length; i++) {byteNumbers[i] = slice.charCodeAt(i);}const byteArray = new Uint8Array(byteNumbers);byteArrays.push(byteArray);}const blob = new Blob(byteArrays, { type: 'audio/wav' });const fileName = 'output.wav';saveAs(blob, fileName);console.log("音频已保存为 " + fileName);}}).catch(error => {console.error("保存音频失败", error);});
}

3、总结:

  1. Base64 解码:使用 atob 将 Base64 编码的字符串解码成字节字符。
  2. 字节转换:将解码后的字符转换为字节数组。
  3. Blob 创建:将字节数组用 Blob 封装,并指定 MIME 类型为 audio/wav
  4. 保存文件:使用 FileSaver.js 的 saveAs 函数保存生成的音频文件。

这样就可以将从后台获得的 Base64 编码的音频数据保存为 WAV 文件到本地。


http://www.mrgr.cn/news/5599.html

相关文章:

  • MobPush扩展业务功能设置
  • uniapp实现应用内检测版本更新(Android直接下载/ios跳转app store)
  • 怎麼在不同系統(Windows、Mac)和流覽器(Google、Firefox)切換代理IP
  • 工厂模式和策略模式区别
  • 电力调度控制台作为智能电网的中枢大脑,引领能源高效调度新时代
  • Redis配置及idea部分操作
  • 深度学习加速秘籍:PyTorch torch.backends.cudnn 模块全解析
  • c语言杂谈系列:模拟虚函数
  • verilog实现STFT
  • 第七届强网杯-PWN-【WTOA】
  • 深夜小灶|如何利用comfyUI生成《黑神话:悟空》风格的建筑效果图
  • LeetCode面试题Day15|LC219 存在重复元素Ⅱ、LC229 汇总区间
  • [RCTF2015]EasySQL1
  • Kuberneters Pod调度基础
  • sqlite blob 数据检索(基于sqlite3_get_table的优化)
  • 如何将TRIZ技术融入到智能家居的产品设计流程中?
  • 【图文并茂】ant design pro 如何优雅奇妙地让创建和更新页面共用一个 form
  • 0x01 GlassFish 任意文件读取漏洞复现
  • 使用 Python和 FFmpeg 批量截图视频到各自文件夹中
  • 【Fiddler】Fiddler抓包工具(详细讲解)_抓包工具fiddler