news 2026/4/16 10:46:40

手把手教你实现:当 GitHub 收到 Star 后,通过企微外部群自动通知

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
手把手教你实现:当 GitHub 收到 Star 后,通过企微外部群自动通知

QiWe开放平台 · 个人名片

API驱动企微自动化,让开发更高效

核心能力:为开发者提供标准化接口、快速集成工具,助力产品高效拓展功能场景

官方站点:https://www.qiweapi.com

团队定位:专注企微API生态的技术服务团队

对接通道:搜「QiWe 开放平台」联系客服

核心理念:合规赋能,让企微开发更简单、更高效


GitHub Webhook 会在特定事件发生时向你的服务器发送POST请求,我们的目标是解析它,并调用企微add_msg_template接口。

1. 业务流程设计

  1. GitHub 发起 Webhook:包含仓库名、操作者、事件类型。

  2. Go 接口验证签名:确保请求真的来自 GitHub,防止恶意攻击。

  3. 构造卡片消息:根据不同事件(如 Star 或 New Issue)渲染不同的文案。

  4. 异步推送企微:避免阻塞 GitHub 的回调连接。

2. 代码实现:Go 语言版本

我们使用Gin框架来快速搭建服务。

package main import ( "crypto/hmac" "crypto/sha256" "encoding/hex" "fmt" "io" "net/http" "github.com/gin-gonic/gin" ) const ( githubSecret = "your_github_webhook_secret" qwToken = "your_qywx_access_token" ) func main() { r := gin.Default() r.POST("/github/webhook", func(c *gin.Context) { // 1. 验证 GitHub 签名 body, _ := io.ReadAll(c.Request.Body) signature := c.GetHeader("X-Hub-Signature-256") if !verifySignature(githubSecret, signature, body) { c.JSON(403, gin.H{"error": "Invalid signature"}) return } // 2. 获取事件类型 event := c.GetHeader("X-GitHub-Event") // 3. 异步处理消息发送,不影响 GitHub 的回调响应 go processGithubEvent(event, body) c.JSON(200, gin.H{"status": "accepted"}) }) r.Run(":8080") } // verifySignature 验证签名安全性 func verifySignature(secret, signature string, body []byte) bool { h := hmac.New(sha256.New, []byte(secret)) h.Write(body) expected := "sha256=" + hex.EncodeToString(h.Sum(nil)) return hmac.Equal([]byte(expected), []byte(signature)) } func processGithubEvent(event string, body []byte) { // 解析 JSON 并调用之前写的 SendExternalGroupMsg 接口 // 如果是 "watch" (Star) 事件 -> 发送:🌟 新增一个 Star! // 如果是 "issues" 事件 -> 发送:🛠 有人提了新 Issue。 fmt.Printf("处理 GitHub 事件: %s\n", event) }

3. 如何配置 GitHub 端?

  1. 进入你的 GitHub 仓库设置 ->Settings->Webhooks->Add webhook

  2. Payload URL: 填写你的服务器地址(如http://your-ip:8080/github/webhook)。

  3. Content type: 选择application/json

  4. Secret: 填写你在代码中定义的githubSecret

  5. Which events: 选择Let me select individual events,勾选StarsIssues

4. 关键避坑点

  • 公网地址问题:GitHub 无法访问你的localhost。开发调试时,可以使用ngrokcrawlee等工具做内网穿透。

  • Star 事件的特殊性:在 Webhook 中,Star 事件对应的名称是watch,而不是star

  • 内容去重:GitHub 有时会因为网络问题重发 Webhook。建议在 Go 中对X-GitHub-Delivery(唯一请求 ID)做 1 分钟内的去重处理。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 20:19:39

二十年“架骨注魂”的旅程

摘要 数字化转型的成功,不取决于技术的先进与否,而取决于管理思想(血肉灵魂) 与数字系统(骨骼架构) 能否在互动中相互塑造,形成具有自适应能力的 “数字共生体” 。 本系列旨在为这场深刻变革提…

作者头像 李华
网站建设 2026/4/13 16:24:12

如何处理 React 中事件处理程序的绑定问题

如何处理 React 中事件处理程序的绑定问题 —— 从「this 丢失」到「性能飙红」的实战手册 一句话总结:用「箭头函数 useCallback 传参模板」三件套,让事件绑定既安全又高性能! 一、为什么要「处理」事件绑定? React 事件绑定…

作者头像 李华
网站建设 2026/4/15 22:13:11

论文降重 + 去 AIGC 双 buff!虎贲等考 AI 让学术合规率飙升 98%

“查重率 35% 改到崩溃,越改逻辑越乱”“AI 写的初稿被检测出 AIGC 痕迹,直接打回重写”“降重只换同义词,导师批‘学术性丧失’”—— 论文写作的最后一道坎,往往是 “降重” 与 “去 AIGC 痕迹”。很多人陷入 “降重 改字”“去…

作者头像 李华
网站建设 2026/4/16 10:41:16

HoloOcean水下机器人模拟器:从1.0到2.0的重大升级

随着水下机器人技术的快速发展,高保真仿真平台已成为算法开发、系统验证和任务预演的关键工具。HoloOcean 作为一款基于游戏引擎构建的开源水下机器人模拟器,自2022年发布以来,已成为学术界和工业界的重要工具。近日,其开发团队发…

作者头像 李华
网站建设 2026/4/11 15:23:55

Python计算机毕设之基于python养老社区的查询预约系统养老服务预约系统(完整前后端代码+说明文档+LW,调试定制等)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华