我的节点服务器使用 Watson TTS api 来合成客户端使用 POST 发送的文本。将 TTs 流写入使用计数器 (1.ogg,2.ogg...) 命名的文件,完成后,发送回文件名。客户端将其加载到音频标签中并播放音频。
虽然我正在使用 createWriteStream 的 on('finish'),但有时会在客户端出现错误,无法加载文件,好像还没有:
GET http://localhost/tts_server/audio/24.ogg 412 (Precondition Failed)
Uncaught (in promise) DOMException: Failed to load because no supported source was found.
此外,如果计数器(以及文件名)为 1,它总是会失败。如果要合成的文本很长,它经常会失败。
客户端相关代码
$.post("http://192.168.0.4:3000", { text : text }, function(data){
player.src = 'audio/' + data.count + '.ogg';
player.oncanplaythrough = player.play();
});
服务端相关代码
var count = 10;
// function to TTS with Watson
function syntText(texto, cb){
var tts = new TextToSpeechV1 ({
username: '****',
password: '****'
});
var params = {
text: texto,
voice: 'es-ES_EnriqueVoice',
accept: 'audio/ogg;codecs=opus'
};
var ws = fs.createWriteStream('../audio/' + count + '.ogg');
ws.on('finish', cb);
tts.synthesize(params).pipe(ws);
}
// post
app.post('/', function(req, res){
syntText(req.body.text, function(){ //body parser here
res.json({count : count});
count++;
});
});
谢谢