如何在Microsoft Bot Framework中避免“抱歉,我的机器人代码有问题”

我有一个运行在Azure + Bot Framework + LUIS(通过LuisDialog)的机器人。

如果用户碰巧快速连续发送两条消息(在机器人有机会回答之前),他们会在Facebook Messenger或web embed上看到此错误消息:

对不起,我的机器人代码出了问题。

通过bot通道模拟器进行调试时,我发现错误是这样的:

“text”:“错误:响应状态代码未指示成功:429(请求太多)。位于System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务)的System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(任务任务) Microsoft.Bot.Builder.Luis.LuisService.d__4.MoveNext()

堆栈跟踪的结尾显示错误源自MessageController.cs中的此行:

await Conversation.SendAsync(activity, () => new LuisRootDialogEnglish()); 

这很奇怪,因为我使用的是付费版本的LUIS,每秒最多可以拨打10个电话。

在任何情况下,我都尝试将MessageController.cs中的整个代码包装到try / catch块中,并且无论exception如何都返回此值:

 return Request.CreateResponse(HttpStatusCode.OK); 

仍然,用户看到错误消息“抱歉,我的机器人代码有问题”,这基本上意味着存在未处理的exception。

如何防止向用户显示此消息或捕获exception?

消息仅在PostUnhandledExceptionToUserTask发送给用户,因为exception已转义根对话框A.您可以通过防止未处理的exception转义根对话框A来避免这种情况。

一种选择是添加一个不同的根对话框B,只需调用对话框A,然后忽略传递给ResumeAfter回调的IAwaitable结果。

Chain.DefaultIfException提供对话框B的实现。

您可以使用Bot Framework的DefaultIfExceptionfunction在内部处理exception。

它看起来像这样:

 await Conversation.SendAsync( activity, () => new Dialogs.RootDialog().DefaultIfException() );