我正在尝试进入 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 中使用单引号和双引号,但尝试转义引号无济于事。有人知道我应该调查什么吗?