- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想设置 botkit 以使用 Microsoft Bot Framework。
botkit 在其“入门”页面上引用了 yeoman 生成器:https://botkit.ai/getstarted.html
此生成器询问应用程序 ID 和应用程序密码。
我转到我在 azure 中创建的 channel -> 设置来获取我的应用程序 ID。复制“Microsoft App ID”中的值并将鼠标悬停在信息图标上,告诉我单击“管理”以获取密码。单击“管理”,这会将我带到“未找到”页面。 (根据旧文章,这应该有效,我猜这是因为迁移?https://learn.microsoft.com/en-us/azure/bot-service/bot-service-quickstart-registration?view=azure-bot-service-3.0)
之后我在这里关注了一篇关于检索应用程序密码的微软博客文章:https://blog.botframework.com/2018/07/03/find-your-azure-bots-appid-and-appsecret/
按照步骤中的说明将其输入到模拟器中后。它说:“未经授权”。
作为消息传递端点,我放置了我的 ngrok 转发的 URL。 (使用 ./ngrok http 3000
检索)
我有什么遗漏的吗?让它正常工作应该非常简单,不是吗?
最佳答案
要使 Botkit 与 BotFramework 配合使用,您只需要配置一些项目。将您的内容与下面的内容进行比较,记下任何差异,并进行适当的更改。我已经完成了这个简单的设置。
首先,如果您不知道,可以通过以下方式找到您的 BotFramework appId 和 appPassword。
导航到 Azure 机器人的资源组。在左侧菜单 Pane 中,选择部署。
然后选择机器人部署并在菜单 Pane 中选择输入。然后,这将列出您的 appId 和 appPassword。
将此代码放入您的index.js 文件中。请务必执行必要的 npm 安装。
const { MemoryStorage } = require('botbuilder');
const { Botkit, BotkitBotFrameworkAdapter } = require('botkit');
const path = require('path');
// Note: Ensure you have a .env file.
const ENV_FILE = path.join(__dirname, '.env');
require('dotenv').config({ path: ENV_FILE });
const storage = new MemoryStorage();
const controller = new Botkit({
adapter: BotkitBotFrameworkAdapter,
adapterConfig: {
appId: process.env.MicrosoftAppId,
appPassword: process.env.MicrosoftAppPassword
},
storage: storage,
webhook_uri: '/api/messages',
});
controller.hears('hello', 'message', async function(bot, message) {
await bot.reply(message, 'Hello yourself');
});
将您的 appId 和 appPassword 包含在 .env 文件中并进行以下设置。
MicrosoftAppId=<appId>
MicrosoftAppPassword=<appPassword>
使用 node index.js
从项目的根目录运行机器人。
最后,在模拟器中,将消息传递端点设置为 http://localhost:3000/api/messages
并包含相同的“Microsoft 应用程序 ID”和“Microsoft 应用程序密码”凭据。
设置模拟器后,通过键入消息进行测试。该机器人正在等待“hello”,并且只会响应该用户输入。
此时您应该可以开始了。
希望得到帮助!
关于node.js - 通过模拟器连接时 Botkit 未经授权(Microsoft Bot Framework),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56893364/
据我所知,要将声音设置为铃声,应将其插入 MediaStore。在 MediaStore 中写入,需要 WRITE_EXTERNAL_STORAGE 权限。但是...有没有办法在不需要 WRITE_E
我只是想设置铃声。我不想授予 WRITE_SETTINGS 权限,我可以找到大部分答案来授予 WRITE_SETTINGS 权限但是我正在使用一个应用程序,该应用程序没有设置铃声的 WRITE_SET
我在 Windows 10 中以管理员身份运行 Android studio。AVD 是 Nexus 5X API 28。我正在尝试运行 flutter 演示,但设备下拉框仍然显示“无设备”,它只是有
我的应用程序构建于 spring-social-twitter允许用户使用 Twitter 登录的功能最近已停止工作。 我收到如下错误消息: Callback URL not approved for
我正在尝试使用 python-firebase 更新 Firebase库,但无法使用经过修改的示例代码进行身份验证: from firebase import firebase as fb auth
今天,当我尝试使用 GCC7 编译一个非常简单的 C++ 程序时,我遇到了一个非常奇怪的问题:程序没有向构造函数中的 vector 添加任何元素,当编译时没有优化(例如 -O0/-Og ) 来自 Re
简单问题:我正在尝试使用 Discord API 备份服务器(或公会,如果您使用官方术语)上的所有消息。 因此,我实现了 OAuth,没有任何问题,我有访问 token ,并且可以查询一些端点(我尝试
您好,我正在使用 msdn 中的以下代码供我公司内部使用: using System; public sealed class Singleton { private static volati
我们从 Google 的 GCM 服务中收到间歇性的 401 Unauthorized 错误。在过去,它 100% 的时间都有效。该问题可能与我们的路由器接受 IPv6 流量同时发生,但即使我们在适配
我有一个使用 Playwright + TS-Jest 设置 E2E 测试的项目。为了组织我的测试,我使用页面对象模型。结构看起来像这样: 我想在 tsconfig.json 中使用 TypeScri
我有一个后端应用程序在 Google Cloud Storage 中同步文件,我想在 javascript 中列出存储中的所有文件,而不需要从后端请求它们。我已经设置了 CORS,并且所有文件的 ac
我在尝试在私有(private) gitlab 存储库中发布 Artifact 时遇到问题。我正在使用 Maven 并使用个人访问 token 进行身份验证。当我运行 mvn deploy -s ~/
这是从 Google+ 登录中使用的 GoogleApiClient 获取 token 的传统方式: String token = GoogleAuthUtil.getToken(apiClient.
我在阅读 facebook Open Graph 文档后比较确定我不能让网站“订阅”公共(public)页面,除非该页面安装了我的应用程序。如果那是错误的,请告诉我。 我想做的是一个照片库,非常简单,
我是一名优秀的程序员,十分优秀!