尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

Spring Boot 常用注解详解:@Slf4j、@RequestMapping、@Autowired/@Resource 对比

Spring Boot 常用注解详解:@Slf4j、@RequestMapping、@Autowired/@Resource 对比
📅 发布时间:2026/6/19 18:26:45

1. @Slf4j 作用

@Slf4j 是 Lombok 提供的注解,用于自动生成日志对象。

作用

  • 自动生成一个名为 log 的静态 final 日志对象(类型为 Logger)
  • 无需手动写 private static final Logger log = LoggerFactory.getLogger(类名.class);

使用示例

不使用 @Slf4j(传统方式):

import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class UserService { private static final Logger log = LoggerFactory.getLogger(UserService.class); public void test() { log.info("这是一条日志"); log.error("错误日志"); } }

使用 @Slf4j(简化方式):

import lombok.extern.slf4j.Slf4j; @Slf4j public class UserService{ public void test(){ log.info("这是一条日志"); //直接用log,无需手动创建 log.error("错误日志"); } }

日志级别

  • log.trace() - 跟踪信息
  • log.debug() - 调试信息
  • log.info() - 一般信息
  • log.warn() - 警告信息
  • log.error() - 错误信息

2. @RequestMapping

@RequestMapping 是 Spring MVC 的注解,用于将请求 URL 映射到控制器方法。

作用

  • 定义请求路径与处理方法的映射关系
  • 可指定请求方法(GET、POST、PUT、DELETE 等)
  • 可指定请求参数、请求头等条件

使用示例

基本用法:

@Controller @RequestMapping("/user") public class userController{ @RequestMapping("/login") public Stirng login{ return "login"; } @RequestMapping(value="/register",method=RequestMethod.POST) public String register{ return "register"; } }

指定请求方法

@RequestMapping(value = "/info", method = RequestMethod.GET) // 只接受 GET 请求 public String getInfo() { return "info"; } // 或者使用更简洁的注解 @GetMapping("/info") // 等同于上面的写法 @PostMapping("/create") // 等同于 @RequestMapping(method = RequestMethod.POST) @PutMapping("/update") // 等同于 @RequestMapping(method = RequestMethod.PUT) @DeleteMapping("/delete") // 等同于 @RequestMapping(method = RequestMethod.DELETE)

指定请求参数:

@RequestMapping(value="/search",params="keyword") //必须有keyword参数 public String search(){ return "result"; }

常用属性

  • value / path:请求路径
  • method:请求方法(GET、POST 等)
  • params:请求参数条件
  • headers:请求头条件
  • produces:响应内容类型(如 application/json)
  • consumes:请求内容类型

3. @Autowired 和 @Resource 区别

两者都用于依赖注入,但来源、默认策略和使用场景不同。

对比表

特性@Autowired@Resource
来源Spring 框架JDK(JSR-250 标准)
默认注入方式按类型(byType)按名称(byName)
找不到时的处理抛出异常(可用 required=false 避免)抛出异常
支持支持 @Qualifier 指定名称支持 name 属性指定名称
使用场景Spring 项目推荐更通用,不依赖 Spring

详细说明

@Autowired(Spring 注解)

默认按类型注入:

@Service public class userService{ // Spring 会查找类型为 UserMapper 的 Bean @Autowierd private UserMapper userMapper; }

按名称注入(需要配合 @Qualifier):

@Service public class UserService{ //如果有多个UserMapper实现,需要指定名称 @Autowired @Qualifier("userMapperImpl") //指定Bean名称 privarte UserMapper userMapper; }

允许为空(避免启动失败):

@Autowired(required=false) //如果找不到Bean,不会报错 private UserMapper userMapper;

构造函数注入(推荐方式):

@Service public class UserService{ private final UserMapper userMapper; @Autowired //Spring4.3+可以忽略 public UserService(UserMapper userMapper){ this.userMapper=userMapper; } }
@Resource(JDK 注解)

默认按名称注入:

@Service public class UserService { // 先按名称 "userMapper" 查找,找不到再按类型查找 @Resource private UserMapper userMapper; }

指定名称注入:

@Service public class UserService { @Resource(name = "userMapperImpl") // 明确指定 Bean 名称 private UserMapper userMapper; }

按类型注入(需要指定 type):

@Resource(type = UserMapper.class) // 按类型注入 private UserMapper userMapper;

实际使用建议

推荐使用 @Autowired:

  • Spring 项目
  • 按类型注入更直观
  • 支持构造函数注入(更安全,避免循环依赖)

使用 @Resource:

  • 需要按名称注入
  • 希望代码不依赖 Spring(但实际还是 Spring 容器管理)

最佳实践:

@Service public class UserService { // 推荐:使用构造函数注入,无需 @Autowired(Spring 4.3+) private final UserMapper userMapper; private final RedisTemplate<String, Object> redisTemplate; public UserService(UserMapper userMapper, RedisTemplate<String, Object> redisTemplate) { this.userMapper = userMapper; this.redisTemplate = redisTemplate; } }

总结

  1. @Slf4j:Lombok 注解,自动生成日志对象,简化日志代码
  2. @RequestMapping:Spring MVC 注解,映射请求路径到处理方法
  3. @Autowired vs @Resource:
  • @Autowired 默认按类型注入,Spring 推荐
  • @Resource 默认按名称注入,JDK 标准
  • 两者功能相似,但注入策略不同

相关新闻

  • Windows平台APK安装器:重新定义安卓应用体验
  • 百度网盘秒传神器:告别传统传输,3步实现极速文件分享
  • 5个让PS4游戏体验翻倍的隐藏技巧

最新新闻

  • 深度解析macOS滚动事件拦截:构建专业级定制插件的完整指南
  • 常州多年黄金回收攻略,三十年实体经营,收的顶本地口碑有保障 - 奢侈品回收测评
  • 01_系统架构设计
  • 如何免费实现专业级直播抠像:obs-backgroundremoval插件完全指南
  • 新手必看!抖音保存视频到相册的详细步骤技巧 - 工具软件使用方法推荐
  • LaTeX长表格排版进阶:如何用longtable宏包实现跨页表格的精细控制?

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号