栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

DialogFlow V2 Webhook-立即获得语音响应,而不是在异步请求之后

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

DialogFlow V2 Webhook-立即获得语音响应,而不是在异步请求之后

它在V1中起作用的原因是

ask()
实际上会发送请求。

使用V2,您可以

add()
多次调用以同一回复将所有内容发送给用户。因此,它需要知道何时发送消息。它是处理处理程序响应的一部分。

如果您的处理程序是同步的,它将立即发送答复。

但是,如果您的处理程序是异步的,则它将假定您正在返回一个Promise,并等待该Promise解析之后再发送答复。因此,要处理异步调用,您需要返回一个Promise。

由于您的呼叫已经在使用Promises,因此您的状态非常好!重要的是您还要 返回
Promise并使用它。因此,这样的事情可能是您的异步​​调用(返回了Promise):

exports.someAsyncCall = function someAsyncCall() {    var apigClient = getAWSClient(); // uses aws-api-gateway-client    return apigClient.invokeApi(params, pathTemplate, method, additionalParams, body)    .then(function(result){        var result = result.data;        var message = result['message'];        console.log('SUCCESS: ' + message);        return Promise.resolve( message );    }).catch( function(error){        console.log('ERROR: ' + error);        return Promise.reject( error );    });};

然后您的Intent处理程序将类似于

function exampleIntent(app) {    return myClient.someAsyncCall()    .then( function( message ){      app.add("You should hear this message": message);      return Promise.resolve();    })    .catch( function( err ){      app.add("Uh oh, something happened.");      return Promise.resolve();  // Don't reject again, or it might not send the reply    })}


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/452465.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号