如何用JavaScript录制麦克风音频并提交到DialogFlow?

如何用JavaScript录制麦克风音频并提交到DialogFlow?,javascript,base64,dialogflow-es,audio-recording,google-cloud-speech,Javascript,Base64,Dialogflow Es,Audio Recording,Google Cloud Speech,如何用JavaScript从麦克风录制音频并将其提交给DialogFlow,而无需通过服务器?这个问题有两个部分: 如何以DialogFlow将理解的格式录制麦克风音频。 如何通过正确的身份验证将音频提交到DialogFlow。 第一部分 对于以DialogFlow将理解的格式录制麦克风音频,我使用,然后使用以下代码转换它返回的blob: function BlobToDataURL(blob: Blob) { return new Promise((resolve, reject)=&

如何用JavaScript从麦克风录制音频并将其提交给DialogFlow,而无需通过服务器?

这个问题有两个部分:

如何以DialogFlow将理解的格式录制麦克风音频。 如何通过正确的身份验证将音频提交到DialogFlow。 第一部分 对于以DialogFlow将理解的格式录制麦克风音频,我使用,然后使用以下代码转换它返回的blob:

function BlobToDataURL(blob: Blob) {
    return new Promise((resolve, reject)=>{
        const reader = new FileReader();
        reader.addEventListener("loadend", e=>resolve(reader.result as string));
        reader.readAsDataURL(blob);
    }) as Promise<string>;
}

const micRecorder = new Recorder({
    encoderSampleRate: 16000,
    originalSampleRateOverride: 16000, // necessary due to Google bug? (https://github.com/chris-rudmin/opus-recorder/issues/191#issuecomment-509426093)
    encoderPath: PATH_TO_ENCODER_WORKER_JS,
});
micRecorder.ondataavailable = async typedArray=>{
    const audioData = new Blob([typedArray], {type: "audio/ogg"});
    const audioData_dataURL = await BlobToDataURL(audioData);
    const audioData_str = audioData_dataURL.replace(/^data:.+?base64,/, "");

    // here is where you need part 2, to actually submit the audio to DialogFlow
};
micRecorder.start();
第二部分
要将音频数据提交到DialogFlow,请参见我的回答:

为什么要进行向下投票?我问了这个问题,这样我就可以在得到充分解释后马上回答。您不仅需要录制音频,还必须将其转换为DialogFlow能够理解的特定格式之一。nice+从我这里得到1。