【发布时间】:2020-07-18 20:57:38
【问题描述】:
我正在使用 Microsoft bot 框架 4 构建聊天机器人。我想将对话内容存储在 SQL Server 数据库中,并想使用实体框架检索它们。
我尝试添加从数据库获取数据的代码,但模拟器报告错误。以下是我的代码:
protected override async Task OnMembersAddedAsync(IList<ChannelAccount> membersAdded, ITurnContext<IConversationUpdateActivity> turnContext, CancellationToken cancellationToken)
{
foreach (var member in membersAdded)
{
if (member.Id != turnContext.Activity.Recipient.Id)
{
var start = GetStartDialog();
if (start != null) {
var attachments = new List<Attachment>();
var reply = MessageFactory.Attachment(attachments);
var b = new HeroCard() { Title = start.Title, Text = start.Body, Buttons = new List<CardAction>() { new CardAction() { Title = "Option 1", Value = 1, Type = ActionTypes.MessageBack }, new CardAction() { Title = "Option 2", Value = 2, Type = ActionTypes.MessageBack } } };
reply.Attachments.Add(b.ToAttachment());
await turnContext.SendActivityAsync(reply, cancellationToken);
}
}
}
}
public Dialog GetStartDialog()
{
BOTEntities db = new BOTEntities();
Dialog retVal = db.Dialogs.Where(o => o.DialogID.Equals(1)).FirstOrDefault();
return retVal;
}
关于为什么我的代码没有执行的任何想法?
提前感谢您的帮助。
【问题讨论】:
-
接受/投票支持更大的 Stack Overflow 社区和任何有类似问题的人。如果您觉得我的回答足够,请“接受”并点赞。如果没有,请告诉我我还能提供哪些帮助!
标签: c# sql-server botframework