收藏
回答

小程序的录音文件格式(wav和MP3)和标准的格式是不一样吗?上传到后端保存下来打不开,显示0:00

请问小程序录音现在支持WAV了是吗(文档里有说明了),但是我将录音(MP3和WAV都试过)上传到后端之后,保存在本地用播放器打不开,时间显示0:00,但是在浏览器里能够打开,请问小程序的音频格式和标准的格式是不是不一样呢,这个如何解决呢,谢谢。

小程序代码(部分)

//上传录音
  upload:function(){
    wx.uploadFile({
      url"http://localhost:8080/voice/upload",//演示域名、自行配置
      filePath: this.tempFilePath,
      name'file',
      header: {
        "Content-Type""multipart/form-data"
      },


//开始录音的时候
  startfunction () {
    const options = {
      duration10000,//指定录音的时长,单位 ms
      sampleRate16000,//采样率
      numberOfChannels1,//录音通道数
      encodeBitRate96000,//编码码率
      format'mp3',//音频格式,有效值 aac/mp3
      frameSize50,//指定帧大小,单位 KB
    }
    //开始录音
    recorderManager.start(options);
    recorderManager.onStart(() => {
      console.log('recorder start')
    });


后端代码:

public String upload(HttpServletRequest request, @RequestParam("file")MultipartFile[] files){
    LOGGER.info("上传测试");
    //多文件上传
    if(files!=null && files.length>=1) {
        BufferedOutputStream bw = null;
        try {
            String fileName = files[0].getOriginalFilename();
            //判断是否有文件(实际生产中要判断是否是音频文件)
            if(StringUtils.isNoneBlank(fileName)) {
                //创建输出文件对象
                File outFile = new File(uploadPath + UUID.randomUUID().toString()+ FileUtil.getFileType(fileName));
                //拷贝文件到输出文件对象
                FileUtils.copyInputStreamToFile(files[0].getInputStream(), outFile);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if(bw!=null) {bw.close();}
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    return "success";
}


希望能得到回复,谢谢。

回答关注问题邀请回答
收藏

1 个回答

  • ؞咬了你؞F࿆ū࿆t࿆ū࿆r࿆ē࿆
    ؞咬了你؞F࿆ū࿆t࿆ū࿆r࿆ē࿆
    2020-06-05

    你是不是在开发者工具里上存的?

    顺便吐槽一下,既然有logger,为什么catch异常要e.printStackTrace(),这样不好。。。


    2020-06-05
    有用
    回复 2
    • Charlie Li
      Charlie Li
      2020-06-05
      好的,谢谢,问题解决啦,开发工具本身有问题,用真机测试就ok啦
      2020-06-05
      回复
    • ؞咬了你؞F࿆ū࿆t࿆ū࿆r࿆ē࿆
      ؞咬了你؞F࿆ū࿆t࿆ū࿆r࿆ē࿆
      2020-06-05回复Charlie Li
      我上个月也是被这个坑住,直到无意间看到开发者工具里的警告。。。
      2020-06-05
      回复
登录 后发表内容
问题标签