- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 v3 (C#) SDK 创建了一个机器人,欢迎消息过去工作得很好,没有任何问题。它在生产中仍然对我有用。代码在 HandleSystemMessage 中是这样处理的——
.. v3 Code 为清楚起见删除了额外的代码...
else if (message.Type == ActivityTypes.ConversationUpdate)
{
// Handle conversation state changes, like members being added and removed
// Use Activity.MembersAdded and Activity.MembersRemoved and Activity.Action for info
// Not available in all channels
//Code to show Welcome Message
if (message.MembersAdded.Any(o => o.Id == message.Recipient.Id))
{
var reply = message.CreateReply();
reply.Attachments = new List<Attachment>();
// Create the attachment.
Attachment attachment = new Attachment()
{
ContentType = AdaptiveCard.ContentType,
Content = AdaptiveCardHelper.GetOptionsCard()
};
reply.Attachments.Add(attachment);
ConnectorClient connector = new ConnectorClient(new Uri(message.ServiceUrl));
await connector.Conversations.ReplyToActivityAsync(reply);
}
}
我使用的 Web Chat 版本是 BotFramework-WebChat-0.11.4,我在其中做了一些定制以实现带有评论的 facebook Like/Unlike 功能。
现在我正在将机器人迁移到 v4 SDK(C# + .Net Core Web App),并且我打算使用相同的旧版本的网络聊天。但是我苦苦挣扎了两天才能在同一个网络聊天中显示一条欢迎消息,同时它在模拟器(给那两个 ConversationUpdate)事件上运行良好。
我已尝试使用本文提供的解决方案发送消息和事件,并尝试在 Bot 中使用不同的异步方法 OnEventAsync、OnEventActivityAsync、OnMessageActivityAsync 捕获它。
V4 代码如下所示:
protected override async Task OnConversationUpdateActivityAsync(ITurnContext<IConversationUpdateActivity> turnContext, CancellationToken cancellationToken)
{
if (turnContext.Activity.MembersAdded != null)
{
if (turnContext.Activity.MembersAdded.Any(m => m.Id != turnContext.Activity.Recipient?.Id))
{
//var welcomeCard = CreateAdaptiveCardAttachment();
//var response = CreateResponse(turnContext.Activity, welcomeCard);
//await turnContext.SendActivityAsync(response, cancellationToken);
await Utility.LogTraceAsync("Inside OnConversationUpdateActivityAsync");
var eventActivity = turnContext.Activity.AsConversationUpdateActivity();
ConnectorClient connector = new ConnectorClient(new Uri(eventActivity.ServiceUrl), Configuration.MicrosoftAppId, Configuration.MicrosoftAppPassword);
await Utility.LogTraceAsync("Service URL OnConversationUpdateActivityAsync" + eventActivity.ServiceUrl);
await Utility.LogTraceAsync("Recipient ID OnConversationUpdateActivityAsync" + turnContext.Activity.Recipient?.Id);
var welcomeCard = CreateAdaptiveCardAttachment();
var reply = ((Activity)eventActivity).CreateReply();
reply.Attachments.Add(welcomeCard);
//var response = CreateResponse(turnContext.Activity, welcomeCard);
await connector.Conversations.ReplyToActivityAsync(reply, cancellationToken);// turnContext.SendActivityAsync(response, cancellationToken);
await Utility.LogTraceAsync("OnConversationUpdateActivityAsync Response Returned.");
await Utility.LogTraceAsync("Exit OnConversationUpdateActivityAsync");
}
}
}
protected override async Task OnEventActivityAsync(ITurnContext<IEventActivity> turnContext, CancellationToken cancellationToken)
{
await Utility.LogTraceAsync("Inside OnEventActivityAsync");
if (turnContext.Activity.Type == ActivityTypes.Event)
{
var eventActivity = turnContext.Activity.AsEventActivity();
await Utility.LogTraceAsync("Event Activity from WebChat matched.");
ConnectorClient connector = new ConnectorClient(new Uri(eventActivity.ServiceUrl), Configuration.MicrosoftAppId, Configuration.MicrosoftAppPassword);
await Utility.LogTraceAsync("Service URL " + eventActivity.ServiceUrl);
var welcomeCard = CreateAdaptiveCardAttachment();
var reply = ((Activity)eventActivity).CreateReply();
reply.Attachments.Add(welcomeCard);
var members = await connector.Conversations.GetConversationMembersAsync(eventActivity.Conversation.Id.ToString());
var membernames = "";
foreach (var member in members) {
membernames += member.Name + ",";
}
await Utility.LogTraceAsync(membernames);
await connector.Conversations.SendToConversationAsync(reply, cancellationToken);
await connector.Conversations.ReplyToActivityAsync(reply, cancellationToken);// turnContext.SendActivityAsync(response, cancellationToken);
await Utility.LogTraceAsync("Event Response Returned.");
}
await Utility.LogTraceAsync("Exit OnEventActivityAsync");
}
但是好像一点作用都没有。我很紧张,不知道如何为 .Net Core App 做事。我很高兴知道是否有人解决了这个问题。
更新 - 我在客户端使用了@tdurnford 提供的 JS 代码,在 Bot 端使用了以下两种方法 -
//Required to Show Welcome Message on Emulator
protected override async Task OnMembersAddedAsync(IList<ChannelAccount> membersAdded, ITurnContext<IConversationUpdateActivity> turnContext, CancellationToken cancellationToken)
{
foreach (var member in membersAdded ?? Array.Empty<ChannelAccount>())
{
// Greet anyone that was not the target (recipient) of this message.
// To learn more about Adaptive Cards, see https://aka.ms/msbot-adaptivecards for more details.
if (member.Id != turnContext.Activity.Recipient.Id)
{
Activity reply = ((Activity)turnContext.Activity).CreateReply();
AdaptiveCard card = AdaptiveCardHelper.GetWelcomeCard();
Attachment attachment = new Attachment()
{
ContentType = AdaptiveCard.ContentType,
Content = card
};
reply.Attachments.Add(attachment);
await turnContext.SendActivityAsync(reply, cancellationToken);
}
}
}
//Required to Show Welcome Message on Web Chat
protected override async Task OnEventActivityAsync(ITurnContext<IEventActivity> turnContext, CancellationToken cancellationToken)
{
if (turnContext.Activity.Name == "webchat/join")
{
Activity reply = ((Activity)turnContext.Activity).CreateReply();
AdaptiveCard card = AdaptiveCardHelper.GetWelcomeCard();
Attachment attachment = new Attachment()
{
ContentType = AdaptiveCard.ContentType,
Content = card
};
reply.Attachments.Add(attachment);
await turnContext.SendActivityAsync(reply, cancellationToken);
}
}
这两种方法都会在聊天窗口中显示两条欢迎消息 -
Bot Window with two Welcome Messages
然后我在 C# 中注释了 OnEventActivityAsync 方法并再次部署。现在它只显示一条从 OnMembersAddedAsync 返回的欢迎消息,如窗口中所示。
Bot Window with only one Welcome Message
如果我在网络聊天代码中注释以下代码行,即不发送后期事件 -
botConnection.postActivity({
from: {
id: 'myUserId',
name: 'myUserName'
},
type: 'event',
name: 'webchat/join',
value: {
locale: 'en-US'
}
}).subscribe(
id => console.log("Posted welcome event, assigned ID ", id),
error => console.log("Error posting activity", error)
);
在这种情况下,不会显示任何欢迎消息。 @tdurnford,请检查您是否能够复制此行为。
尽管这种方式存在另一个问题,即当用户在机器人中输入问题时,会再次显示欢迎消息。 Bot window with two welcome messages one on load and another after the first question
最佳答案
通常, channel 会在对话初始化时发送两个对话更新事件 - 一个用于机器人,另一个用于用户。第二个 - 用户事件 - 旨在触发欢迎消息。与其他一些 channel 不同,网络聊天会等待发送第二个对话更新事件,直到用户向机器人发送消息。显然,在第一条消息之后才会发送欢迎消息。要解决此问题,开发人员可以在建立 DirectLine 连接时向机器人发送反向 channel 欢迎事件,并从 onEventAsync 处理程序而不是 onMembersAdded 发送欢迎消息。有关详细信息,请查看下面的代码片段。
机器人聊天代码
<!DOCTYPE html>
<html>
<head>
<link href="https://cdn.botframework.com/botframework-webchat/0.11.4/botchat.css" rel="stylesheet" />
<style>
#webchat {
height: 100%;
width: 100%;
}
</style>
</head>
<body>
<div style="display: flex">
<div style="position: relative; height: 500px; width: 500px"><div id="bot" ></div></div>
</div>
<script src="https://cdn.botframework.com/botframework-webchat/0.11.4/botchat.js"></script>
<script>
(async function() {
const res = await fetch('/directline/token', { method: 'POST' });
const { token } = await res.json();
var userinfo = {
id: 'user-id',
name: 'user name',
locale: 'es'
};
var botConnection = new window.BotChat.DirectLine({ token });
botConnection.connectionStatus$
.subscribe(connectionStatus => {
switch(connectionStatus) {
case window.BotChat.ConnectionStatus.Online:
botConnection.postActivity({
from: { id: 'myUserId', name: 'myUserName' },
type: 'event',
name: 'webchat/join',
value: { locale: 'en-US' }
}).subscribe(
id => console.log("Posted welcome event, assigned ID ", id),
error => console.log("Error posting activity", error)
);
break;
}
});
BotChat.App({
botConnection: botConnection,
user: userinfo,
bot: { id: 'botid' },
resize: 'detect'
}, document.getElementById("bot"));
})().catch(err => console.log(err));
</script>
</body>
</html>
机器人代码 - C#
protected override async Task OnEventActivityAsync(ITurnContext<IEventActivity> turnContext, CancellationToken cancellationToken)
{
if (turnContext.Activity.Name == "webchat/join") {
await turnContext.SendActivityAsync("Welcome Message!");
}
}
protected override async Task OnMembersAddedAsync(IList<ChannelAccount> membersAdded, ITurnContext<IConversationUpdateActivity> turnContext, CancellationToken cancellationToken)
{
if (turnContext.Activity.ChannelId != "webchat" && turnContext.Activity.ChannelId != "directline") {
foreach (var member in membersAdded)
{
if (member.Id != turnContext.Activity.Recipient.Id)
{
await turnContext.SendActivityAsync($"Hi there - {member.Name}. {WelcomeMessage}", cancellationToken: cancellationToken);
await turnContext.SendActivityAsync(InfoMessage, cancellationToken: cancellationToken);
await turnContext.SendActivityAsync(PatternMessage, cancellationToken: cancellationToken);
}
}
}
}
屏幕截图
另请注意,Web Chat v0.11.4 称为 Bot Chat 或 Web Chat v3。对不起,我被绊倒了。
希望这对您有所帮助!
关于c# - 在 v4 Bot Framework Bot(C# + .Net Core Web 应用程序)中显示欢迎消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56863203/
因此,我想创建一个 bot/incoming webhook 来读取群组中的所有消息并将其复制到电子表格中。我在这里要问的是,机器人或传入的 webhook 可以读取整个群组消息吗?在 google
我正在使用 Microsoft Bot Framework 开发一个机器人,在该机器人中,机器人将通过向用户发送一些图像来响应。我用 slack 和 skype 配置了它。 在 slack 中图像正在
我试图让我的机器人与用户开始对话,但我不知道应该从代码中的哪个位置发送消息。启动 convo 的文档在这里,但不是很有帮助:http://docs.botframework.com/connector
我正在创建 Telegram Bot 。我需要跟踪添加用户和添加用户的时间。我如何使用 Telegram API 来做到这一点? 最佳答案 在使用 Telegram API 的群组中,您可以调用 ne
我已经创建了几个 Telegram 机器人。它们适用于我的帐户,也适用于我测试过的其他几个帐户。 但我收到一些用户的报告,称机器人从不响应。 是否有一些用户设置会阻止帐户从机器人获取消息?或者任何其他
如果在一段时间内没有用户输入,我有一个关于取消提示或对话框的问题。 我需要一种方法来以某种方式在提示中超时。 Example: Bot prompts the user: "How old are y
我有一个用例,当我的机器人需要在一天中的特定时间向用户发送消息时。假设每天早上 6 点。 我正在使用预定的 azure Webjob 发送这些消息。消息将在 Slack 和 Skype 客户端中传递。
我是 Microsoft bot 的新手。我的公司有自己的通信应用程序,我想将我的机器人与通信应用程序连接起来,我的客户可以在我公司的通信应用程序上使用我的机器人。我读到它需要使用 Direct Li
我在 sdk V4 Bot 中实现了一个中间件来拦截 bot 和用户之间的每条消息并记录该自定义 mongo Db。我正在尝试为使用 SDK v4 构建的 Bot 实现类似的概念。看起来我可以使用以下
我对编程和学习还很陌生。我认为制作一个不和谐的机器人是一种很好的学习方式,我很享受,只是有点卡住了。所以我的机器人是私有(private)的,我们的不和谐服务器中有一个正在运行的笑话,每当用户发送“k
如何让机器人假装它正在输入消息? 当机器人假装输入时,聊天中会出现以下文本: 我使用 python aiogram框架,但对 native Telegram API 的建议也会有所帮助。 最佳答案 我
我有一个像这样的 Telegram Bot : 通过 webhook 获取更新 语言:C#(我也欢迎其他语言的回答) 我们有以下用户场景: 向机器人发送/MyPhoto a_parameter命令 向
我加入了一个 Telegram Bot ,但我不知道它的所有者。是否可以找到 Telegram Bot 的所有者? 最佳答案 根据 Telegram MTProto protocol 不可能看到 Te
我已经创建了一个电报机器人并按照文档中的描述设置了一个 webhook。出于测试目的,我已经设置了它,因此一旦您向机器人发送一条消息,它就会用相同的消息回复。 现在我遇到的问题是来自电报的更新非常缓慢
是否可以将位置从 Telegram 发送到 Bot,这是在 Bot Framework 中制作的? 我将我的位置从我的 Telegram 帐户发送到我的 Bot,但服务器没有收到它们(我没有收到回复)
我在 Telegram 上创建了一个组并创建了一个机器人并添加进来。 我正在尝试向我创建的组发送消息,错误如下所示 {"ok":false,"error_code":403,"description"
使用 Microsoft Bot Framework V3 我开始使用登录卡。 我从示例代码页做了一个简单的剪切并粘贴到我的代码中,假设它有效(编译): https://docs.botframewo
当用户刚刚打开聊天时,机器人如何向用户发送消息。 例子: 用户已经添加了 Telegram bot到他的联系人列表并开始对话 稍后,用户打开与该机器人的聊天窗口 机器人“看到”该用户已打开聊天窗口,但
将 XCode 更新到版本 11.4 (11E146) 后,我不再在机器人设置中看到存储库分支。但是我在 Source Controll Navigator 中看到了这些存储库分支。有谁知道我该如何解
我想将机器人的位置发送给用户,我在谷歌上搜索了很多,但我发现只有这种情况“将用户的位置发送给机器人”我想要相反的情况,意思是:“发送机器人的位置给用户”。这是我的想法:机器人的所有者是一个司机,他想与
我是一名优秀的程序员,十分优秀!