fc33b3eb68
* docs: transfer AstrBotDevs/AstrBot-docs to AstrBotDevs/AstrBot * refactor: reorder imports and improve type hints in sync_docs_to_wiki.py and upload_doc_images_to_r2.py * feat: add GitHub Actions workflow to sync wiki with documentation Co-authored-by: Soulter <37870767+Soulter@users.noreply.github.com> Co-authored-by: anka-afk <110004162+anka-afk@users.noreply.github.com> Co-authored-by: zouyonghe <62183434+zouyonghe@users.noreply.github.com> Co-authored-by: shuiping233 <49360196+shuiping233@users.noreply.github.com> Co-authored-by: LIghtJUNction <106986785+LIghtJUNction@users.noreply.github.com> Co-authored-by: Sjshi763 <179909421+Sjshi763@users.noreply.github.com> Co-authored-by: xiewoc <70128845+xiewoc@users.noreply.github.com> Co-authored-by: QingFeng-awa <151742581+QingFeng-awa@users.noreply.github.com> Co-authored-by: PaloMiku <96452465+PaloMiku@users.noreply.github.com> Co-authored-by: shangxueink <138397030+shangxueink@users.noreply.github.com> Co-authored-by: IGCrystal-A <244300990+IGCrystal-A@users.noreply.github.com> Co-authored-by: RC-CHN <67079377+RC-CHN@users.noreply.github.com> Co-authored-by: MC090610 <113341105+MC090610@users.noreply.github.com> Co-authored-by: Waterwzy <196913419+Waterwzy@users.noreply.github.com> Co-authored-by: Lanhuace-Wan <186303160+Lanhuace-Wan@users.noreply.github.com> Co-authored-by: LiAlH4qwq <61769640+LiAlH4qwq@users.noreply.github.com> Co-authored-by: HSOS6 <209910899+HSOS6@users.noreply.github.com> Co-authored-by: th-dd <162813557+th-dd@users.noreply.github.com> Co-authored-by: miaoxutao123 <81676466+miaoxutao123@users.noreply.github.com> Co-authored-by: nuomicici <143102889+nuomicici@users.noreply.github.com> Co-authored-by: nasyt233 <210103278+nasyt233@users.noreply.github.com> Co-authored-by: jlugjb <7426462+jlugjb@users.noreply.github.com> Co-authored-by: Raven95676 <176760093+Raven95676@users.noreply.github.com> Co-authored-by: Futureppo <180109455+Futureppo@users.noreply.github.com> Co-authored-by: MliKiowa <61873808+MliKiowa@users.noreply.github.com> Co-authored-by: Fridemn <150212937+Fridemn@users.noreply.github.com> Co-authored-by: BakaCookie520 <138355736+BakaCookie520@users.noreply.github.com> Co-authored-by: YumeYuka <125112916+YumeYuka@users.noreply.github.com> Co-authored-by: xming521 <32786500+xming521@users.noreply.github.com> Co-authored-by: ywh555hhh <121592812+ywh555hhh@users.noreply.github.com> Co-authored-by: stevessr <89645372+stevessr@users.noreply.github.com> Co-authored-by: roeseth <41995115+roeseth@users.noreply.github.com> Co-authored-by: ikun-1145141 <265925499+ikun-1145141@users.noreply.github.com> Co-authored-by: evpeople <54983536+evpeople@users.noreply.github.com> Co-authored-by: Yue-bin <60509781+Yue-bin@users.noreply.github.com> Co-authored-by: W1ndys <109416673+W1ndys@users.noreply.github.com> Co-authored-by: TheFurina <218887821+TheFurina@users.noreply.github.com> Co-authored-by: Seayon <12275933+Seayon@users.noreply.github.com> Co-authored-by: OnlyblackTea <38585636+OnlyblackTea@users.noreply.github.com> Co-authored-by: ocetars <74854972+ocetars@users.noreply.github.com> Co-authored-by: railgun19457 <117180744+railgun19457@users.noreply.github.com> Co-authored-by: JunieXD <107397009+JunieXD@users.noreply.github.com> Co-authored-by: advent259141 <197440256+advent259141@users.noreply.github.com> Co-authored-by: Doge2077 <91442300+Doge2077@users.noreply.github.com> Co-authored-by: Bocity <23430545+Bocity@users.noreply.github.com> Co-authored-by: Aurora-xk <192227833+Aurora-xk@users.noreply.github.com>
149 lines
6.9 KiB
Markdown
149 lines
6.9 KiB
Markdown
# AstrBot 接入企业微信
|
||
|
||
AstrBot 支持接入企业微信应用和微信客服。
|
||
|
||
## 支持的基本消息类型
|
||
|
||
> 版本 v4.15.0。
|
||
|
||
| 消息类型 | 是否支持接收 | 是否支持发送 | 备注 |
|
||
| --- | --- | --- | --- |
|
||
| 文本 | 是 | 是 | |
|
||
| 图片 | 是 | 是 | |
|
||
| 语音 | 是 | 是 | |
|
||
| 视频 | 否 | 是 | |
|
||
| 文件 | 否 | 是 | |
|
||
|
||
主动消息推送:企业微信应用支持,未测试企业微信客服。
|
||
|
||
## 准备接入
|
||
|
||
步骤:
|
||
|
||
1. 进入 AstrBot 的管理面板
|
||
2. 点击左边栏 `机器人`
|
||
3. 然后在右边的界面中,点击 `+ 创建机器人`
|
||
4. 选择 `wecom`
|
||
|
||
这将弹出一个对话框。接下来,不要关闭页面,转移到下一步。
|
||
|
||
## 接入方式一:微信客服
|
||
|
||
> [!NOTE]
|
||
>
|
||
> 1. 需要 >= v3.5.7
|
||
> 2. 以这种方式接入,支持在微信内使用。
|
||
|
||
1. 进入 [微信客服后台](https://kf.weixin.qq.com/),使用企业微信扫码登录。
|
||
|
||
2. **得到客服账号名。** 在 `客服账号` 中创建一个客服账号,记录下名称,填入 AstrBot 配置的 `微信客服账号名` 中(不是账号 ID)。
|
||
|
||
3. **得到企业 ID。** 在 [企业微信 - 企业信息](https://work.weixin.qq.com/wework_admin/frame#profile) 得到企业 ID(`Corpid`),复制到 AstrBot 配置的 `corpid` 处。
|
||
|
||
4. **回调服务器验证。** 如果您之前没有使用过微信客服机器人,那么请在 `开发配置` 中点击企业内部接入右侧的 `开始使用` 按钮,您应该会看到回调配置的页面。
|
||
|
||

|
||
|
||
如果您之前使用过微信客服机器人,那么在 `开发配置` 中直接找到 `回调配置`,点击修改。
|
||
|
||
点击下方的两个随机获取,得到 `Token` 和 `EncodingAESKey`,复制到 AstrBot 配置的 `token` 和 `encoding_aes_key` 处。请保持 `统一 Webhook 模式 (unified_webhook_mode)` 为开启状态。然后点击保存配置,等待适配器加载完成。
|
||
|
||
回调 URL 填写:
|
||
|
||
- 如果开启了 `统一 Webhook 模式`,点击保存之后,AstrBot 将会自动为你生成唯一的 Webhook 回调链接,你可以在日志中或者 WebUI 的机器人页的卡片上找到,将该链接填入回调 URL 处。
|
||
|
||

|
||
|
||
- 如果没有开启 `统一 Webhook 模式`,填写 `http://你的带公网地址的服务器ip:6195/callback/command`。
|
||
|
||
> 请注意放行端口。如果开启了统一 Webhook 模式,需要将请求转发到 AstrBot 所在服务器的 `6185` 端口;如果没有开启,则转发到配置指定的端口(默认 `6195`)。
|
||
|
||
回到微信客服 `回调配置`,点击 `完成`。如果一切无误,将会显示 `已完成`(否则会显示类似 `openapi 回调不通过` 类似的文本)。
|
||
|
||
1. **获取 Secret。** 之后,在 `开发配置` 中得到 Secret,找到复制到刚刚创建的企业微信适配器,点击编辑,然后修改配置中的 `secret`。然后再次保存配置,等待适配器加载完成。
|
||
|
||
> [!TIP]
|
||
> 根据 [#571](https://github.com/Soulter/AstrBot/issues/571) 的反馈,对于新注册的企业,`corp_id` 可能要注册一段时间后才生效(前后大概过了半个小时)。
|
||
|
||
然后,打开 `控制台` 页,你应该会看到如下日志:
|
||
|
||
```txt
|
||
请打开以下链接,在微信扫码以获取客服微信 ...
|
||
```
|
||
|
||

|
||
|
||
打开链接,用微信扫码,然后即可打开微信客服聊天页,输入 `help` 测试是否正常连通。
|
||
|
||
## 接入方式二:企业微信应用
|
||
|
||
进入 https://work.weixin.qq.com/wework_admin/frame#apps
|
||
|
||
点击 `我的企业`,查看并得到企业 ID(`Corpid`),复制到 AstrBot 配置的 `corpid` 处。
|
||
|
||
> [!TIP]
|
||
> 根据 [#571](https://github.com/Soulter/AstrBot/issues/571) 的反馈,对于新注册的企业,`corp_id` 可能要注册一段时间后才生效(前后大概过了半个小时)。
|
||
|
||

|
||
|
||
点击下面的 `自建应用`,然后点击 `创建应用`,填写好应用名称、头像、应用可见范围等信息。
|
||
|
||
进入应用,查看并得到机器人的 `Secret`,复制到 AstrBot 配置的 `secret` 处。
|
||
|
||

|
||
|
||
在下方,找到 `接收消息`,点击 `设置 API 接收`,进入 API 接收页面。
|
||
|
||

|
||
|
||

|
||
|
||
并且点击下方的两个随机获取,得到 `Token` 和 `EncodingAESKey`,复制到 AstrBot 配置的 `token` 和 `encoding_aes_key` 处。建议保持 `统一 Webhook 模式 (unified_webhook_mode)` 为开启状态。
|
||
|
||
现在应该已经填完 AstrBot 连接到企业微信的所有配置项。点击 AstrBot 配置页右下角保存,等待 AstrBot 重启。
|
||
|
||
在 URL 处填入回调地址:
|
||
|
||
- 如果开启了 `统一 Webhook 模式`,点击保存之后,AstrBot 将会自动为你生成唯一的 Webhook 回调链接,你可以在日志中或者 WebUI 的机器人页的卡片上找到,将该链接填入 URL 处。
|
||
|
||

|
||
|
||
- 如果没有开启 `统一 Webhook 模式`,填入 `http://你的带公网地址的服务器ip:6195/callback/command`。
|
||
|
||
> 请注意放行端口。如果开启了统一 Webhook 模式,需要将请求转发到 AstrBot 所在服务器的 `6185` 端口;如果没有开启,则转发到配置指定的端口(默认 `6195`)。
|
||
|
||
接下来配置企业可信 IP。
|
||
|
||

|
||
|
||
将你的 公网 IP 地址填写到此处,点击确定。
|
||
|
||
|
||
重启成功后,回到API 接收页面,点击下面的保存,看是否能\够保存成功。如果出现 `openapi 请求回调地址不通过` 说明配置有问题,请检查四个配置项是否填写正确。
|
||
|
||
如果能够保存成功,AstrBot 就已经能够接收信息。
|
||
|
||
## 测试
|
||
|
||
在企业微信-工作台中,找到刚刚创建的应用,发送 `/help`,看看 AstrBot 是否能够回复。
|
||
|
||

|
||
|
||
## 反向代理(自定义 API BASE)
|
||
|
||
AstrBot 支持自定义企业微信的终结点以适应家庭 ip 没有固定的公网 IP 问题。
|
||
|
||
只需要将您的自定义地址填入 `api_base_url` 即可。
|
||
|
||
> 如果您没有公网 ip 当然也可以购买一台服务器,推荐 阿里云 的 99 元/年的服务器。
|
||
|
||
## 语音输入
|
||
|
||
为了语音输入,需要你的电脑上安装有 `ffmpeg`。
|
||
|
||
linux 用户可以使用 `apt install ffmpeg` 安装。
|
||
|
||
windows 用户可以在 [ffmpeg 官网](https://ffmpeg.org/download.html) 下载安装。
|
||
|
||
mac 用户可以使用 `brew install ffmpeg` 安装。
|