在企业微信的开发场景中,我们经常遇到这样的需求:系统产生了一单新业务,需要自动通知到包含客户的"外部群"中。然而,如果你尝试用传统的 Webhook 机器人,会发现它在外部群中受到诸多限制。
要实现真正的"主动推送",目前主流且合规的方案主要有以下三种:
1. 客户群群发接口(最推荐的合规方案)
这是官方提供的标准能力,适用于企业向客户群发送通知、素材或活动信息。
-
实现原理 :开发者调用
add_msg_template接口,创建一套消息模板。 -
交互逻辑:系统调用接口后,该群的"群主"(员工)会在企业微信收到一条"服务通知"。员工点击"发送",消息才会正式进入外部群。
-
优点:支持文本、图片、链接、小程序卡片;合规性高,不容易被封号。
-
局限性:无法做到"完全静默"推送,必须经过员工的一次确认点击。
2. 应用消息推送(路径较深)
如果你的外部群是围绕某个"自建应用"建立的,可以利用应用能力进行触达。
-
实现原理:通过企业微信自建应用,向群成员发送应用消息。
-
场景建议:这更倾向于一对一触达,或者引导用户点击进入小程序/H5后再进行后续操作。
3. 群机器人 Webhook(有条件限制)
这是开发成本最低的方案,但它在外部群中有严格的门槛。
-
现状:目前企业微信限制了"含有微信联系人"的外部群直接添加 Webhook 机器人。
-
例外情况:部分由微信侧发起的互通群,或者在特定行业版本下,机器人权限会有所不同。
-
建议:在开发前,务必先手动测试目标群聊是否允许添加"群机器人"插件。
技术实现核心流程(以群发接口为例)
如果你决定采用方案1,其核心开发步骤如下:
第一步:获取 AccessToken
调用所有 API 的前提,确保你的应用拥有"客户联系"权限。
第二步:配置发送范围
你需要准备好目标群聊的 chat_id 列表。这些 ID 可以通过"获取客户群列表"接口预先拉取并存储在你的数据库中。
第三步:构造消息体
python
{
"chat_type": "group",
"sender": "ZhuRongji",
"chat_id_list": ["oc_xxx", "oc_yyy"],
"text": {
"content": "您有一条新的业务订单需要处理"
},
"attachments": [
{
"msgtype": "link",
"link": {
"title": "查看详情",
"picurl": "https://example.com/icon.png",
"desc": "点击处理业务单据",
"url": "https://example.com/detail"
}
}
]
}
第四步:员工确认
接口调用成功后,会返回一个 msgid。此时,对应的群主会收到推送,手动确认后完成闭环。
开发避坑指南
-
频率限制:企业微信对外部群发有频次限制(通常为每个群每天可接收的消息条数有限),设计逻辑时需增加业务过滤,避免无效推送。
-
ChatID 的持久化 :外部群的
chat_id是相对稳定的,建议在群成员变动回调中同步更新数据库,避免向已解散或退出的群发送消息。 -
用户体验:由于需要员工"确认发送",建议在系统后台增加一个"待办提醒",防止员工忽略了企业微信端的服务通知。
总结
外部群的主动推送核心在于**"合规"与"触达"**的平衡。通过 API 创建模板并配合员工确认,是目前企业级应用中最稳健的解决方案。
QiWe开放平台提供了后台直登功能,登录成功后获取相关参数,快速Apifox在线测试,所有登录功能都是基于QiWe平台API自定义开发。