Skip to main content

WeCom Bot Callback Server Simple Framework

Project description

企业微信机器人回调服务

如果项目能给你带来些许便利,请不吝 Star

  • 2024-12-09 新增发送主动文件功能(可以由消息触发)
  • 2025-02-08 新增主动发送消息服务(本地网络POST触发)

1. 介绍

本项目是一个基于 Flask企业微信机器人回调功能的接口服务简单框架 。使用者只需要实现两个简单的函数,即可快速搭建一个企业微信机器人回调功能的接口服务。

实现过程参考企业微信机器人回调功能说明文档 ,以及相关文档中指引使用的加解密脚本

2. 使用

这里提供一个 demo.py,只要安装好依赖,修改好配置,即可直接进行部署服务。

2.1 本地调试

需要安装依赖,然后拉起 demo.py 即可(这里暂时使用固定的 token 和 AESKey,后续在实际配置时可以替换掉):

pip3 install wecom-bot-svr
python3 demo.py

拉起服务后,可以使用 curl 进行测试(下边的测试链接对应demo中原始的 token 和 AESKey):

curl 'http://127.0.0.1:5001/wecom_bot?msg_signature=09380007d4f0891d966988e5450ad794c77fa01c&timestamp=1703041184&nonce=1703023880&echostr=oCdlC8pJ%2FDIjXnC8F9reyjDYlSImCmIgxA4prPD%2Bl2Fj5qBHjFiWnpelQofsDCJrSEvNVTET6oQmoXLQxzUkyQ%3D%3D'

2.2 Docker方式部署

如果你计划单独的去部署这个机器人回调服务,可以直接使用我这里提供的Docker方式。

cd demo
docker build -t wx_bot docker.io/panzhongxian/wecom-bot-svr-demo:latest .
docker push docker.io/panzhongxian/wecom-bot-svr-demo:latest

然后在对应的平台中选择镜像部署,配置好对应的域名,即可获得在后续步骤中需要的回调地址。

如果你需要跟别的服务部署在一起,或者直接在CVM的机器上启动,在运行之前,记得安装 wecom-bot-svr 即可

2.3 配置企业微信群机器人

找一个群,在右上角点击「...」,点击「添加群机器人」,点击「接收消息配置」, 这里对应 demo 我们填入回调地址、token、AESKey。

new_wecom_bot

如果服务正常,这里将会保存成功;如果服务异常,这里会提示失败。

2.4 测试

在添加到群中之后,可以在群中发送消息。demo里有实现 help 和普通消息的回复功能:

add_wecom_bot

也可以移除再添加,这里展示的是加入群的事件触发消息发送的功能:

wecom_bot_join

2.5 发布到公司

查看机器人资料,有一个发布到公司的按钮,只有发布之后的机器人,才能被公司其他同事搜索到,才可以被添加到其他的群聊当中:

publish_wecom_bot

3. Token和AESKey的管理

为了方便,demo中直接使用固定的 Token 和 AESKey,实际使用中,建议直接利用机器人配置页面的随机生成按钮获得。

random_token_1

删除代码中传入的 token 和 key,直接将其以配置的方式传入到服务中即可( 三个环境变量 WX_BOT_TOKEN, WX_BOT_AES_KEY, WX_BOT_CORP_ID):

server = app.WecomBotServer(bot_name, host, port, path='/wecom_bot')
random_token_2

4. demo.py 代码解析

只要你看懂了 demo.py 里边做了什么工作,就可以修改他,实现自己机器人的回复逻辑了。

  • msg_handler: 消息处理函数,简单的实现了 help 和普通消息的回复功能
  • event_handler: 事件处理函数,简单的实现了加入群聊的事件触发消息发送的功能
  • WecomBotServer: 企业微信机器人回调服务的接口服务,实现了加解密的功能,运行后能拉起 HTTP 服务
  • 通过set_message_handlerset_event_handler将消息处理函数和事件处理函数注册到服务中

消息格式说明

msg_handler(req_msg) -> rsp_msg:消息处理函数将接收一个请求消息对象,返回一个响应消息对象。

所有机器人接收到的消息和事件,罗列在 req_msg.py 中,会作为 msg_handler 的输入,已经提取到具体的格式,用户可以根据自己的需求使用。

机器人发送消息只有两种形式,一种是 Text,另外一种是 Markdown,定义在 rsp_msg.py 文件当中。两种消息都只需要填写 content 内容即可。

5. 发送文件

send_file

原理链接:https://developer.work.weixin.qq.com/document/path/91770#%E6%96%87%E4%BB%B6%E7%B1%BB%E5%9E%8B

将上述上传文件、发送文件进行了封装,作为 WecomBotServer 的一个方法,可以被调用。

可以在消息处理函数中,通过调用 send_file(chat_id, file_path) 方法,将文件发送到群聊中。

当然,你也可以通过其他方式,调用该函数主动发送。

这里需要在构造函数中,增加传入 bot_key,用于发送文件的权限校验。这个key是在 WebHook 的链接中可以查询到:

webhook_key.png

同时,你需要加在消息处理函数的参数中,增加 server 参数,用于调用发送文件的方法。

def msg_handler(req_msg: ReqMsg, server: WecomBotServer):
    ...
    # 生成文件、发送文件可以新启线程异步处理
    with open('output.txt', 'w') as f:
        f.write("This is a test file. Welcome to star easy-wx/wecom-bot-svr!")
    server.send_file(req_msg.chat_id, 'output.txt')
    return RspTextMsg()  # 不发送消息,只回复文件

6. 主动触发消息发送

单独启动了一个路由(默认为 /active_send),用于接收主动发送消息的触发。

这样做的好处是可以隔离机器人消息管理和其他需要发送消息的应用,解耦消息发送逻辑消息内容组织与触发的逻辑

考虑到安全性,该路由只处理本地网络的 POST 请求,外网请求会直接返回错误。默认的路由,可以通过路径来指定。

import requests

url = "http://127.0.0.1:5001/active_send"
data = {"msg_type": "text", "chat_id": "12345", "content": "主动消息推送测试"}

response = requests.post(url, data=data)

print(response.text)

以上代码中 chat_id,如果给个人发送则是其ID,如果是群发,则是群的ID。

active_send

7. TODO

  • 增加默认权限支持

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wecom_bot_svr-0.3.3.tar.gz (14.1 kB view details)

Uploaded Source

Built Distribution

wecom_bot_svr-0.3.3-py3-none-any.whl (12.0 kB view details)

Uploaded Python 3

File details

Details for the file wecom_bot_svr-0.3.3.tar.gz.

File metadata

  • Download URL: wecom_bot_svr-0.3.3.tar.gz
  • Upload date:
  • Size: 14.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for wecom_bot_svr-0.3.3.tar.gz
Algorithm Hash digest
SHA256 95c967b2f13ac1b4982b2577b2ef3c12fa9d70e3fd7fdf74049674a59315c277
MD5 179c130c2042454d98ea3b7ad2e1c487
BLAKE2b-256 21d023189b55ab733358d4f26d91f71fae517ff8cef3a91e0367cc0a86040113

See more details on using hashes here.

File details

Details for the file wecom_bot_svr-0.3.3-py3-none-any.whl.

File metadata

File hashes

Hashes for wecom_bot_svr-0.3.3-py3-none-any.whl
Algorithm Hash digest
SHA256 33671959e2db2a3ec3be863707f9a5f75ea64b5f1bfd420c61aee041ad4105a3
MD5 98cd17005250b657d4317bb368d3e671
BLAKE2b-256 fdb0cb1e6d3e3f8a8de28b9837101c9145ef337e1c0c767ae5ba47f66fd1857e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page