企业微信外部群消息推送实战指南

核心逻辑:外部群消息推送的两种方式

  1. Webhook 机器人方式(最简单):

    • 场景:手动在群里添加机器人,获取 Webhook 地址。

    • 限制:需要群主开启机器人权限,且外部群可能不支持直接添加(需开启"外部群插件")。

  2. 应用 API 方式(最专业):

    • 场景 :通过自建应用,利用 chat_id 主动推送。

    • 限制 :需要先通过接口获取 chat_id,且该应用必须在客户联系的业务范围内。


代码实现示例

以下均以 应用 API 方式 (/cgi-bin/appchat/send) 为例:

1. Python 实现 (使用 requests)

Python 代码最为简洁,适合做脚本或快速验证。

python 复制代码
import requests
import json

def send_to_external_group(token, chat_id, text):
    url = f"https://qyapi.weixin.qq.com/cgi-bin/appchat/send?access_token={token}"
    data = {
        "chatid": chat_id,
        "msgtype": "text",
        "text": { "content": text },
        "safe": 0
    }
    res = requests.post(url, data=json.dumps(data))
    return res.json()

2. Go 实现 (使用标准库)

Go 适合追求性能的中间件推送服务。

java 复制代码
func SendGroupMsg(token string, chatId string, content string) {
    url := "https://qyapi.weixin.qq.com/cgi-bin/appchat/send?access_token=" + token
    body := map[string]interface{}{
        "chatid":  chatId,
        "msgtype": "text",
        "text":    map[string]string{"content": content},
    }
    jsonBody, _ := json.Marshal(body)
    http.Post(url, "application/json", bytes.NewBuffer(jsonBody))
}

3. Java 实现 (使用 RestTemplate)

Java 方案通常集成在 Spring Boot 项目中。

java 复制代码
public void sendMsg(String token, String chatId, String text) {
    String url = "https://qyapi.weixin.qq.com/cgi-bin/appchat/send?access_token=" + token;
    Map<String, Object> params = new HashMap<>();
    params.put("chatid", chatId);
    params.put("msgtype", "text");
    params.put("text", Collections.singletonMap("content", text));
    
    restTemplate.postForEntity(url, params, String.class);
}

⚠️ 开发者必看的三个"坑"

  • 获取 ChatID 的前置条件:

    你不能通过群名发消息。必须先调用 externalcontact/groupchat/list 获取群列表,再通过 get 接口获取具体的 chat_id。

  • 应用可见性:

    发送消息的应用,必须在企业微信后台配置的"可调用接口的应用"列表中,且群主必须在应用的可见范围内。

  • 发送频率:

    外部群对自动化消息有严格限制。如果短时间内发送频率过高,会导致接口返回 81013 错误或直接封禁应用发送功能。

QiWe开放平台提供了后台直登功能,登录成功后获取相关参数,快速Apifox在线测试,所有登录功能都是基于QiWe平台API自定义开发。

相关推荐
深挖派2 分钟前
GoLand 2026.1 安装配置与环境搭建 (保姆级图文教程)
后端·golang·编辑器·go·goland
迷藏4949 分钟前
**发散创新:基于角色与属性的混合权限模型在微服务架构中的实战落地**在现代分布式系统中,
java·python·微服务·云原生·架构
码以致用17 分钟前
Java垃圾回收器笔记
java·jvm·笔记
暴力袋鼠哥19 分钟前
基于springboot与vue的ai多模态数据展示看板
java·spring boot
用户83071968408228 分钟前
VS Code Java开发配置与使用经验分享
java·visual studio code
立莹Sir31 分钟前
云原生全解析:从概念到实践,Java技术栈如何拥抱云原生时代
java·开发语言·云原生
geovindu32 分钟前
go: Factory Method Pattern
开发语言·后端·golang
程序员老邢42 分钟前
【技术底稿 12】内网统一日志系统 Loki + Promtail 全流程部署(对接 Grafana,监控日志一体化)
java·运维·程序人生·grafana·devops
银河系的一束光1 小时前
使用 IntelliJ IDEA 开发 Java 程序时 , 会遇到以下中文乱码问题 :
java·ide·intellij-idea