当前位置: 首页 > news >正文

【SpringBoot】✈️整合飞书群机器人发送消息

💥💥✈️✈️欢迎阅读本文章❤️❤️💥💥

🏆本篇文章阅读大约耗时3分钟。

⛳️motto:不积跬步、无以千里

📋📋📋本文目录如下:🎁🎁🎁

目录

前言

账号创建

代码实现

         1、添加配置

         2、测试接口

安全校验

章末

前言

        小伙伴们大家好,上篇文章是简单实现了常见的图形验证码的使用,文章链接如下:

【验证码】⭐️集成图形验证码实现安全校验-CSDN博客

        这篇文章来看下,如何整合飞书的群机器人发送自定义消息,一切从简(摆烂 bushi )

账号创建

        本地是在电脑端,点击左上角的加号,选择创建群组,之后在对应群组页面的右上角打开设置,点击群机器人,添加机器人,选择下面这一个即可

         点击创建机器人后可以获取到对应的 webhook 地址

代码实现

         1、添加配置

        将 webhook 加到配置文件中,然后用配置类来读取,将配置类交由 spring 管理

ext:larkBotConfig:webhookUrl: https://open.feishu.cn/open-apis/bot/v2/hook/3e2c19d1-8fdd-4b56-b147-b613e90064a5
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;/**** @author benbenhuang* @date 2025/5/18 21:13*/
@Configuration
@ConfigurationProperties(prefix = "ext")
@Data
public class ExtProperties {private final LarkBotConfig larkBotConfig = new LarkBotConfig();@Datapublic static class LarkBotConfig{private String webhookUrl;}
}
        2、测试接口

        将需要发送的消息,传递给接口,测试下 效果如下:

import cn.hutool.http.HttpRequest;
import com.alibaba.fastjson.JSON;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.Base64;
import java.util.HashMap;
import java.util.Map;/*** @author benbenhuang* @date 2025年05月18日 19:28*/
@RequestMapping("/testLark")
@RestController
@Slf4j
public class LarkController {@Autowiredprivate ExtProperties extProperties;@PostMapping("/send")public void sendLark(@RequestParam("notice") String notice){send(notice);}private void send(String notice){try {Map<String,Object> header=new HashMap();Map<String,Object> text=new HashMap();text.put("text",  notice);header.put("msg_type", "text");header.put("content", text);//发送post请求String result = HttpRequest.post(extProperties.getLarkBotConfig().getWebhookUrl()).body(JSON.toJSONString(header), "application/json;charset=UTF-8").execute().body();log.info("lark resp:{}", result);} catch (Exception e) {log.error("lark发送消息异常", e);}}}

 

安全校验

        1、上面的方式是没有加权限校验的实现,也就是说只要获取到 webhook 链接,谁都可以向这个群里发送消息,针对此情况可以开启群机器人的 权限校验,从这里开启,获取到秘钥之后,点击保存即可

         2、调整配置

        加入秘钥配置:

        3、测试接口

         安全校验具体到代码层面就是,请求参数中根据官方文档中要求的时间戳和加密后的sign值

自定义机器人使用指南 - 开发指南 - 飞书开放平台

@RequestMapping("/teatLark")
@RestController
@Slf4j
public class LarkController {@Autowiredprivate ExtProperties extProperties;@PostMapping("/sendWithToken")public void sendLarkWithToken(@RequestParam("notice") String notice){sendWithSignature(notice);}private void sendWithSignature(String notice) {String secret = extProperties.getLarkBotConfig().getSecret(); // 从 Lark 后台获取String timestamp = String.valueOf(System.currentTimeMillis() / 1000); // 当前时间戳,单位秒String sign = calculateSignature(timestamp, secret);try {Map<String,Object> json=new HashMap();Map<String,Object> text=new HashMap();text.put("text",  notice);json.put("msg_type", "text");json.put("content", text);json.put("timestamp", timestamp);json.put("sign", sign);//发送post请求String result = HttpRequest.post(extProperties.getLarkBotConfig().getWebhookUrl()).body(JSON.toJSONString(json), "application/json;charset=UTF-8").execute().body();log.info("lark resp:{}", result);} catch (Exception e) {log.error("lark发送消息异常", e);}}private static String calculateSignature(String timestamp, String secret) {try {//把timestamp+"\n"+密钥当做签名字符串String stringToSign = timestamp + "\n" + secret;//使用HmacSHA256算法计算签名Mac mac = Mac.getInstance("HmacSHA256");mac.init(new SecretKeySpec(stringToSign.getBytes(StandardCharsets.UTF_8), "HmacSHA256"));byte[] signData = mac.doFinal(new byte[]{});return new String(Base64.getEncoder().encodeToString(signData));} catch (Exception e) {throw new RuntimeException("sign 计算异常");}}}

章末

       文章到这里就结束了~

往期推荐 > > > 

 【服务器搭建】✈️用自己电脑搭建一个服务器!

 【IDEA】✈️自定义模板,自动生成类和方法注释

 【日志链路】⭐️SpringBoot 整合 TraceId 日志链路追踪!

相关文章:

  • Socket.IO是什么?适用哪些场景?
  • Flink的时间问题
  • 微软将于 8 月 11 日关闭 Bing Search API 服务
  • 二叉树构造:从前序、中序与后序遍历序列入手
  • Flink 作业提交流程
  • 数据库中关于查询选课问题的解法
  • JAVA SE 多线程(上)
  • C#中的成员常量:编译时的静态魔法
  • Elasticsearch进阶篇-DSL
  • 虚幻引擎5-Unreal Engine笔记之Pawn与胶囊体的关系
  • 项目:在线音乐播放服务器——基于SSM框架和mybatis
  • 宝塔面板屏蔽垃圾搜索引擎蜘蛛和扫描工具的办法
  • 互联网大厂Java面试场景:从简单到复杂的技术深度解析
  • redis读写一致问题
  • 《从零开始:Spring Cloud Eureka 配置与服务注册全流程》​
  • 记录一次win11本地部署deepseek的过程
  • 开发指南115-CSS中选择器关系
  • 接口——类比摄像
  • 31、魔法生物图鉴——React 19 Web Workers
  • Jmeter使用及压测
  • 新时代,新方志:2025上海地方志论坛暨理论研讨会举办
  • 证监会强化上市公司募资监管七要点:超募资金不得补流、还贷
  • 俄方代表团抵达土耳其,俄乌直接谈判有望于当地时间上午重启
  • 杞支雅男评《1517》|放眼世界,立足德国
  • 有人倒卖试运营门票?上海乐高乐园:这些票存在无法入园风险
  • 长三角首次,在铁三赛事中感受竞技与生态的共鸣