保存为 Blob 的 [object Object] Nodejs

24

我希望使用HTML5从麦克风录制音频,然后将其发送到服务器进行保存。但目前保存的文件只包含[object Object]

以下是我的一些代码片段:

前端:

console.log(blob);
$http.post('/api/save_recording', blob)
  .success(function(new_recording) {
    console.log("success");
  })

日志打印:

Blob {type: "audio/wav", size: 237612, slice: function}
success

后端:

exports.saveRecording = function(req, res) {
  console.log(req.body);

  fs.writeFile("temp/test.wav", req.body, function(err) {
    if(err) {
      console.log("err", err);
    } else {
      return res.json({'status': 'success'});
    }
  }) 
}

日志输出:{ type: 'audio/wav', size: 786476 }

请问为什么这个不起作用,以及如何修复它?


从您的调试中,我看到writeFile正在转换对象,因为在此之前它没有[Object object]的值,但我不太熟悉node.js以回答。$http.post处理传递给它的数据的方式也可能存在问题,因为我过去曾经使用文件上传指令来完成这个任务,我想可能会有一些困难,但是我不太记得具体细节了。 - shaunhusain
1个回答

33

我终于使这个工作起来了。让它工作的方法是在客户端对Blob进行编码,并在服务器上对其进行解码。

前端:

// converts blob to base64
var blobToBase64 = function(blob, cb) {
  var reader = new FileReader();
  reader.onload = function() {
    var dataUrl = reader.result;
    var base64 = dataUrl.split(',')[1];
    cb(base64);
  };
  reader.readAsDataURL(blob);
};

blobToBase64(blob, function(base64){ // encode
  var update = {'blob': base64};
  $http.post('/api/save_recording', update)
    .success(function(new_recording) {
      console.log("success");
    });
});    

后端:

exports.saveRecording = function(req, res) {
  var buf = new Buffer(req.body.blob, 'base64'); // decode
  fs.writeFile("temp/test.wav", buf, function(err) {
    if(err) {
      console.log("err", err);
    } else {
      return res.json({'status': 'success'});
    }
  }); 
};

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接