recorder.js节点到天蓝色说话人识别

问题描述 投票:0回答:1

我有一个浏览器应用程序,该应用程序通过麦克风记录用户的语音,并使用recorder.js将其导出为WAV文件。我认为将其转换为数据URL并将其发布到节点。然后,我尝试将音频发送到Microsoft Azure扬声器识别API,但是我总是收到“无效的音频格式:不是WAVE文件-没有RIFF标头”的信息。

是否有添加RIFF标头的方法,或者关于records.js或与base64相互转换以删除这些标头?有没有办法将它们重新添加?

代码:INDEX.HTML

rec.exportWAV(function (blob) {
    var reader = new window.FileReader();
    reader.readAsDataURL(blob);
    reader.onloadend = function () {
        base64 = reader.result;
        console.log(base64)
        $.ajax({
            type: "POST",
            url: '/addVoiceToProfile',
            data: { userId: '', voiceId: "XXX-XXX", voice: base64, sampleRate: audioContext.sampleRate / 1000 },
            success: function (results) {
                console.log(results)
            }
        })
    }
})

节点路线:

app.post('/addVoiceToProfile', function(req, res){
    var voicedata = req.body.voice;
    var base64Data = voicedata.replace(/^data:([A-Za-z-+/]+);base64,/, '');
    addVoicesToProfile(base64Data, req.body.voiceId).then(function(results){
        res.send(results)
    })
})

addVoicesToProfile:

function addVoicesToProfile(voice, id, user){
    return new Promise(function (resolve, reject) {
        var url = AzureParameters.endPoint+"/spid/v1.0/verificationProfiles/"+id+"/enroll";
        request({
            url:url,
            headers:{'Content-Type':'audio/wave', 'Ocp-Apim-Subscription-Key':AzureParameters.key},
            body: Buffer.from(voice, 'base64').toString('binary'),
            method: "POST",
            json: true
        }, function(err, response, body){
            if(err) return reject(err);
            return resolve(body)
        })
    })
}
javascript azure microsoft-cognitive voice-recognition recorder.js
1个回答
0
投票

似乎问题出在实际上是文件的发送方式。我不知道如果将它以wav的形式发送到帖子正文中,而不是以帖子中的数据形式发送,为什么会起作用,但这是我的工作代码,如果将来对任何人都有用的话:

html:

我将this answer用于html。它包括wav的编码。我所做的唯一更改是,正如答案所示,我将发布到我的服务器,而不是直接发布到MS Azure服务。

节点路线:

这花了我一段时间,因为我无法让节点看到我发送的文件。另外,我正在使用bodyParser,所以我看不到发布请求的原始内容。这是我发帖请求的路线:

  app.post('/uploadAudio', function (req, res, next) {
    var data = new Buffer('');
    req.on('data', function (chunk) {
        data = Buffer.concat([data, chunk]);
    });
    req.on('end', function () {
        req.rawBody = data;
        next();
    });
  }, function (req, res) {
    addVoicesToProfile(req.rawBody)
  })

我希望这对某人有帮助,因为这两个部分都花了我很长时间才能解决!

© www.soinside.com 2019 - 2024. All rights reserved.