我的应用程序中遇到一个神秘的错误。 (在Firebase上运行的NodeJS中编写的Google Assistant + Fulfillment)我的应用程序是购买汽油。 如果您想购买其他东西,例如苹果,它将询问您。 如果想第二次购买其他东西,例如7李子,它将把您重定向到默认意图。这就是它应该如何工作的。 但是,除此之外(请参见屏幕截图)
奇怪的是请求和响应以及错误选项卡为空:(对于其他用例,它们永远不会为空)
在firebase函数内部,我没有看到错误日志,但在GCP日志下却看到一个错误:
{
insertId: "1fmi9ryg1rc8hud"
labels: {
channel: "preview"
querystream: "GOOGLE_USER"
source: "JSON_RESPONSE_VALIDATION"
}
logName: "projects/xxxxxx/logs/actions.googleapis.com%2Factions"
receiveTimestamp: "2019-06-11T17:10:13.712416274Z"
resource: {
labels: {
action_id: "actions.intent.TEXT"
project_id: "xxxxxx"
version_id: ""
}
type: "assistant_action"
}
severity: "ERROR"
textPayload: "MalformedResponse: ErrorId: 113661de-882c-4238-a67a-f324359004a4. Failed to parse Dialogflow response into AppResponse because of invalid platform response. : Could not find a RichResponse or SystemIntent in the platform response for agentId: d7069fa0-5691-4104-848a-56f78e3007c4 and intentId: "
timestamp: "2019-06-11T17:10:13.699816952Z"
trace: "projects/xxxxxxx/traces/ABwppHEdFw2KY23BcC1eOVrIkgUCPC0ae2Sa39ixR7r1mUexFYRhdj2pH-BHNkXky1s9cgLGSw"
}
之所以如此神秘,是因为例如,如果我先说7李子接受,然后再说7苹果,它将进入默认意图。为什么?我不知道如果我输入随机文本(如3 sadjhb),它也会询问,第二次返回默认意图。我知道这不是对问题的正确描述,但我认为它并不能始终如一地工作。
我也可以复制此意图的实现代码,但现在我觉得这与它无关。 我希望你们当中的一个人曾经遇到过这种行为。 谢谢您的阅读!
编辑:
app.intent('service.addgasoline.getinput', (conv, params) => {
if (params.value && params.unittype) {
const outmessage = 'So buy gas for - ' + params.value + ' ' + params.unittype;
conv.ask(outmessage);
conv.ask(new Suggestions(['Yes', 'No']));
} else {
conv.ask('How much gas you want to buy? For example, you can say 1 L or 1 gallon.');
}
});
答案 0 :(得分:1)
我刚刚在我的应用程序中修复了类似的问题。
在我的情况下,问题出在DialogFlow的意图训练短语上。实体的解析值不完全符合预期。
例如,整个短语“ 7 plum”可能被错误地解析为值,而不是其中的“ 7”。