0

我的节点服务器使用 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++;
    }); 
});

谢谢

4

0 回答 0