我無法在向我的服務器端API發出「AJAX」請求時播放音頻。如何播放使用HTML5 Audio API從XMLHTTPRequest返回的音頻
我已經後端目前正使用IBM的沃森文本到語音的服務,服務從文本音頻的Node.js代碼:
var render = function(request, response) {
var options = {
text: request.params.text,
voice: 'VoiceEnUsMichael',
accept: 'audio/ogg; codecs=opus'
};
synthesizeAndRender(options, request, response);
};
var synthesizeAndRender = function(options, request, response) {
var synthesizedSpeech = textToSpeech.synthesize(options);
synthesizedSpeech.on('response', function(eventResponse) {
if(request.params.text.download) {
var contentDisposition = 'attachment; filename=transcript.ogg';
eventResponse.headers['content-disposition'] = contentDisposition;
}
});
synthesizedSpeech.pipe(response);
};
我有客戶端代碼來處理:
var xhr = new XMLHttpRequest(),
audioContext = new AudioContext(),
source = audioContext.createBufferSource();
module.controllers.TextToSpeechController = {
fetch: function() {
xhr.onload = function() {
var playAudio = function(buffer) {
source.buffer = buffer;
source.connect(audioContext.destination);
source.start(0);
};
// TODO: Handle properly (exiquio)
// NOTE: error is being received
var handleError = function(error) {
console.log('An audio decoding error occurred');
}
audioContext
.decodeAudioData(xhr.response, playAudio, handleError);
};
xhr.onerror = function() { console.log('An error occurred'); };
var urlBase = 'http://localhost:3001/api/v1/text_to_speech/';
var url = [
urlBase,
'test',
].join('');
xhr.open('GET', encodeURI(url), true);
xhr.setRequestHeader('x-access-token', Application.token);
xhr.responseType = 'arraybuffer';
xhr.send();
}
}
後端返回我期望的音頻,但我的成功方法playAudio從未被調用過。相反,handleError總是被調用,並且錯誤對象始終爲空。
任何人都可以解釋我做錯了什麼,以及如何糾正?這將不勝感激。
謝謝。
注意:URL中的字符串「test」在後端變成了一個文本參數,並且在synthesizeAndRender中的選項變量中結束。
你確定支持音頻格式嗎? – Musa
我相信它一定是。我最初通過一個url直接用相同的Chrome瀏覽器測試了相同的後端代碼,並且它可以很好地運行。 – exiquio
實際上,測試是在Chromium和Gnu/Linux上完成的。我相信它應該與OSX中的Chrome相同,我現在正在編寫此代碼,但我不確定。 – exiquio