vue上传录音_vue 录音

本文介绍了如何在Vue项目中使用js-audio-recorder库进行录音操作,包括开始、暂停、继续、结束录音,播放录音,下载PCM和WAV文件。同时,补充了录音文件的上传方法,通过创建FormData对象,将录音Blob数据添加到表单并发送POST请求到后端进行处理。
摘要由CSDN通过智能技术生成

引包

npm i js-audio-recorder

调用

import Recorder from 'js-audio-recorder';

let recorder = new Recorder();

实例属性

// 开始录音

recorder.start();

// 暂停录音

recorder.pause();

// 继续录音

recorder.resume()

// 结束录音

recorder.stop();

// 录音播放

recorder.play();

// 销毁录音实例,释放资源,fn为回调函数,

recorder.destroy(fn);

recorder = null;

下载功能

// 下载pcm文件

recorder.downloadPCM();

// 下载wav文件

recorder.downloadWAV();

// 重命名pcm文件,wav也支持

recorder.downloadPCM('重命名');

获取录音时长

// 回调持续输出时长

recorder.onprocess = function(duration) {

console.log(duration);

}

// 手动获取录音时长

console.log(recorder.duration);

更多API事件列表,请参考官方文档

补充说明

文档上未提及上传音频文件方法,只提供了下载方法,这里我补上

var form = new FormData(),

request = new XMLHttpRequest();

form.append("blob", recorder.getPCMBlob());

request.open("POST", this.domain+"/upload/audio/file", true);

request.onload = function (oEvent) {

console.log(oEvent);

};

request.send(form);

后端php接收

//上传录音文件

function upload_audio(Request $request){

/**@var $file UploadedFile*/

$file = $request->files->get("blob");

$fileName=rand(1000,999999).time().".pcm";

$file->move("./user_audio",$fileName);

//调用语音识别方法

$res=$this->speech($fileName);

}

}

总结

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值