4

我正在尝试进入 ASK,我只是尝试了一个 SSML 的虚拟示例。我正在使用 Amazon Lambda 和 Python。如果我从 Lambda 控制台测试我的代码,我会得到预期的输出:

{
  "version": "1.0",
  "response": {
    "outputSpeech": {
      "text": "<speak><audio src='https://s3.amazonaws.com/aws-website-resources-1183x/dice-die-roll.mp3' />Three</speak>",
      "type": "SSML"
    },
    "shouldEndSession": true,
    "card": {
      "content": "Three.",
      "type": "Simple",
      "title": "Dice"
    }
  }
}

当我去 Alexa 服务模拟器并尝试任何请求时,输出语音中的文本消失了,控制台中的“收听”按钮被禁用,如果我在 Echo 上尝试它,它不会播放任何内容:

{
  "version": "1.0",
  "response": {
    "outputSpeech": {
      "type": "SSML"
    },
    "card": {
      "content": "Three.",
      "title": "Dice",
      "type": "Simple"
    },
    "shouldEndSession": true
  }
}

如果我将 SSML 复制/粘贴<speak><audio src='https://s3.amazonaws.com/aws-website-resources-1183x/dice-die-roll.mp3' />Three</speak>到语音模拟器中,我可以播放它并按预期播放。我已经使用 ffmpeg 转换了 mp3 文件:ffmpeg -y -i a.mp3 -ar 16000 -ab 48k -codec:a libmp3lame -ac 1 output.mp3并且我知道亚马逊的 S3 应该是可信的,可能是什么问题?我尝试在 SSML 中使用单引号和双引号,但尝试转义引号无济于事。有人知道我应该调查什么吗?

4

1 回答 1

9

愚蠢的错误。输出应该是 inssml而不是text.

"outputSpeech": {
      "ssml": "<speak><audio src='https://s3.amazonaws.com/aws-website-resources-1183x/dice-die-roll.mp3' />Three</speak>",
      "type": "SSML"
    },
于 2016-08-24T04:55:08.020 回答