news 2026/6/12 14:22:40

手把手封装Utils - 钉钉消息工具类实战教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
手把手封装Utils - 钉钉消息工具类实战教程

手把手封装Utils - 钉钉消息工具类实战教程

前言

在日常开发中,我们经常需要集成各种第三方服务,比如钉钉消息推送。今天我们来手把手封装一个实用的钉钉消息工具类,让你的代码更加优雅和可维护。

完整代码展示

先上完整代码,一睹为快:

importcn.hutool.http.HttpRequest;importcn.hutool.json.JSONUtil;importlombok.extern.slf4j.Slf4j;importorg.springframework.beans.factory.annotation.Value;importorg.springframework.scheduling.annotation.Async;importorg.springframework.stereotype.Component;importjava.util.HashMap;importjava.util.Map;/** * 钉钉消息工具 */@Slf4j@ComponentpublicclassDingTalkUtils{@Value("${dingtalk.platformOperateUrl}")privateStringplatfromOperateUrl;/** * 群里面发送消息 * @param title 消息标题 * @param content 消息内容 */@AsyncpublicvoidsendTextMsg(Stringtitle,Stringcontent){// 组装请求内容StringreqStr=buildReqTextStr(title,content);// 推送消息(http请求)Stringresult=HttpRequest.post(platfromOperateUrl).body(reqStr).execute().body();log.info("钉钉请求发送成功,返回结果:{}",result);}/** * 组装请求报文-text类型 * * @param content 消息内容 * @return */publicstaticStringbuildReqTextStr(Stringtitle,Stringcontent){Map<String,String>contentMap=newHashMap<>();content="【"+title+"】"+"\n"+content;contentMap.put("content",content);Map<String,Object>reqMap=newHashMap<>();reqMap.put("msgtype","text");reqMap.put("text",contentMap);returnJSONUtil.toJsonStr(reqMap);}publicstaticvoidmain(String[]args){DingTalkUtilsdingTalkUtils=newDingTalkUtils();dingTalkUtils.sendTextMsg("测试标题","测试内容");}}

详细解析

1. 依赖引入

首先,我们需要在pom.xml中引入相关依赖:

<!-- Hutool工具包 --><dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.16</version></dependency><!-- Lombok --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency>

2. 配置说明

application.ymlapplication.properties中添加钉钉配置:

dingtalk:platformOperateUrl:https://oapi.dingtalk.com/robot/send?access_token=你的token

3. 核心功能解析

@Slf4j注解

使用Lombok的@Slf4j注解,自动生成日志对象,简化日志记录代码。

@Component注解

将工具类注册为Spring组件,方便依赖注入。

@Async注解

实现异步消息发送,避免阻塞主线程,提升系统性能。

@Value注解

从配置文件中读取钉钉Webhook地址,实现配置与代码分离。

4. 方法详解

sendTextMsg方法
@AsyncpublicvoidsendTextMsg(Stringtitle,Stringcontent)
  • 功能:发送文本消息到钉钉群
  • 参数
    • title:消息标题,会被格式化为【标题】格式
    • content:消息内容
  • 特性:异步执行,不会阻塞调用线程
buildReqTextStr方法
publicstaticStringbuildReqTextStr(Stringtitle,Stringcontent)
  • 功能:构建钉钉文本消息的请求体
  • 返回值:JSON格式的请求字符串
  • 格式化:自动将标题和内容拼接成钉钉支持的格式

5. 使用示例

基本使用
@AutowiredprivateDingTalkUtilsdingTalkUtils;// 发送消息dingTalkUtils.sendTextMsg("系统告警","服务器CPU使用率超过90%");
在异常处理中使用
@ControllerAdvicepublicclassGlobalExceptionHandler{@AutowiredprivateDingTalkUtilsdingTalkUtils;@ExceptionHandler(Exception.class)publicvoidhandleException(Exceptione){log.error("系统异常",e);dingTalkUtils.sendTextMsg("系统异常",e.getMessage());}}

6. 扩展功能

支持Markdown消息
publicvoidsendMarkdownMsg(Stringtitle,Stringcontent){Map<String,String>markdownMap=newHashMap<>();markdownMap.put("title",title);markdownMap.put("text",content);Map<String,Object>reqMap=newHashMap<>();reqMap.put("msgtype","markdown");reqMap.put("markdown",markdownMap);StringreqStr=JSONUtil.toJsonStr(reqMap);Stringresult=HttpRequest.post(platfromOperateUrl).body(reqStr).execute().body();log.info("钉钉Markdown消息发送成功,返回结果:{}",result);}
支持@指定用户
publicvoidsendTextMsgAt(Stringtitle,Stringcontent,List<String>atMobiles){Map<String,Object>reqMap=buildReqTextMap(title,content);Map<String,Object>atMap=newHashMap<>();atMap.put("atMobiles",atMobiles);atMap.put("isAtAll",false);reqMap.put("at",atMap);StringreqStr=JSONUtil.toJsonStr(reqMap);Stringresult=HttpRequest.post(platfromOperateUrl).body(reqStr).execute().body();log.info("钉钉@消息发送成功,返回结果:{}",result);}

7. 最佳实践

1. 错误处理增强
@AsyncpublicvoidsendTextMsg(Stringtitle,Stringcontent){try{StringreqStr=buildReqTextStr(title,content);Stringresult=HttpRequest.post(platfromOperateUrl).body(reqStr).timeout(5000)// 设置超时时间.execute().body();log.info("钉钉消息发送成功,返回结果:{}",result);}catch(Exceptione){log.error("钉钉消息发送失败",e);// 可以在这里实现重试机制或降级处理}}
2. 消息队列解耦
@ServicepublicclassDingTalkService{@AutowiredprivateRedisTemplate<String,Object>redisTemplate;privatestaticfinalStringDINGTALK_QUEUE="dingtalk:queue";publicvoidsendMessageAsync(Stringtitle,Stringcontent){Map<String,String>message=newHashMap<>();message.put("title",title);message.put("content",content);redisTemplate.opsForList().rightPush(DINGTALK_QUEUE,message);}// 通过定时任务或消息监听器处理队列@Scheduled(fixedDelay=1000)publicvoidprocessMessageQueue(){// 处理消息队列}}

总结

通过这个实战案例,我们学习了如何:

  1. 优雅地封装第三方API调用
  2. 使用Spring注解简化开发
  3. 实现异步处理提升性能
  4. 合理设计工具类结构
  5. 考虑扩展性和可维护性

这个钉钉消息工具类不仅功能完善,而且易于扩展。你可以根据实际需求添加更多的消息类型支持,比如链接消息、卡片消息等。

希望这篇文章对你有所帮助,如果有任何问题,欢迎在评论区留言讨论!


更多精彩内容,请关注我的CSDN博客!

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

【独家】从零理解VSCode量子设备仿真器的热更新机制(附实操代码)

第一章&#xff1a;VSCode 量子硬件的更新机制VSCode 作为现代开发的核心工具&#xff0c;其在量子计算领域的集成能力日益增强。随着量子硬件平台如 IBM Quantum、Rigetti 和 IonQ 的快速发展&#xff0c;VSCode 通过插件系统实现了对量子设备状态同步与固件更新的支持。更新机…

作者头像 李华
网站建设 2026/6/11 20:15:45

扫地机器人本地化革命:Valetudo兼容设备完全指南

扫地机器人本地化革命&#xff1a;Valetudo兼容设备完全指南 【免费下载链接】Valetudo Cloud replacement for vacuum robots enabling local-only operation 项目地址: https://gitcode.com/gh_mirrors/va/Valetudo 还记得那个周末吗&#xff1f;你的扫地机器人突然&q…

作者头像 李华
网站建设 2026/6/12 3:00:07

数字人协作系统架构解析:构建实时多用户交互的技术核心

数字人协作系统架构解析&#xff1a;构建实时多用户交互的技术核心 【免费下载链接】awesome-digital-human-live2d Awesome Digital Human 项目地址: https://gitcode.com/GitHub_Trending/aw/awesome-digital-human-live2d 在数字化转型的浪潮中&#xff0c;数字人正从…

作者头像 李华
网站建设 2026/6/10 17:59:41

【提升500%调试速度】:VSCode远程连接性能优化实战全解析

第一章&#xff1a;VSCode远程调试性能优化概述在现代分布式开发环境中&#xff0c;VSCode凭借其轻量级架构与强大的扩展生态&#xff0c;成为远程调试的首选工具。然而&#xff0c;随着项目规模扩大和网络环境复杂化&#xff0c;远程调试常面临响应延迟、资源占用高、文件同步…

作者头像 李华
网站建设 2026/6/10 11:23:17

紧急升级!你的安全审计过时了吗?MCP SC-400量子防御指南速览

第一章&#xff1a;MCP SC-400 量子安全的审计方法随着量子计算的发展&#xff0c;传统加密体系面临前所未有的破解风险。MCP SC-400 是专为应对量子威胁而设计的安全审计框架&#xff0c;其核心目标是验证系统在后量子密码学&#xff08;PQC&#xff09;环境下的完整性、机密性…

作者头像 李华
网站建设 2026/6/11 13:17:40

19、Linux进程管理:用户ID、会话与守护进程详解

Linux进程管理:用户ID、会话与守护进程详解 1. 用户ID相关概念 在Linux系统中,与进程相关的用户ID有三种:真实用户ID(real user ID)、有效用户ID(effective user ID)和保存的用户ID(saved user ID)。 当一个进程执行 exec 调用时,通常有效用户ID不变。但如果执行…

作者头像 李华