Spring Boot常用注解详解:实例与核心概念

Spring Boot常用注解详解:实例与核心概念

前言

Spring Boot作为Java领域最受欢迎的快速开发框架,其核心特性之一是通过注解(Annotation)简化配置,提高开发效率。注解驱动开发模式让开发者告别繁琐的XML配置,专注于业务逻辑实现。本文将介绍Spring Boot中高频使用的核心注解,结合实例帮助开发者快速掌握这些“魔法标签”的用法。


一、启动类与核心注解

1. @SpringBootApplication

作用:标识主启动类,是@Configuration@EnableAutoConfiguration@ComponentScan的组合注解。

@SpringBootApplication
public class DemoApplication {public static void main(String[] args) {SpringApplication.run(DemoApplication.class, args);}
}

二、Web开发相关注解

1. @RestController

作用:组合@Controller@ResponseBody,直接返回JSON数据。

@RestController
@RequestMapping("/api")
public class UserController {@GetMapping("/users")public List<User> getUsers() {return userService.findAll();}
}

2. @RequestMapping 及其变体

各注解适用场景与业务示例

  1. @GetMapping
    适用场景
  • 数据查询操作(符合RESTful规范)
  • 获取资源详情/列表
  • 触发缓存读取
// 示例:获取用户分页列表(配合@RequestParam)
@GetMapping("/products")
public Page<Product> getProducts(@RequestParam(defaultValue = "0") int page,@RequestParam(defaultValue = "10") int size) {return productService.getProducts(page, size);
}
  1. @PostMapping
    适用场景
  • 创建新资源(用户注册、订单提交)
  • 触发需要事务管理的操作
  • 表单提交处理
// 示例:用户注册(配合@RequestBody接收JSON)
@PostMapping("/register")
public ResponseEntity<User> register(@RequestBody UserDTO userDTO) {User newUser = userService.createUser(userDTO);return ResponseEntity.created(URI.create("/users/" + newUser.getId())).body(newUser);
}
  1. @PutMapping
    适用场景
  • 全量更新资源
  • 状态变更操作
// 示例:更新用户信息
@PutMapping("/users/{id}")
public User updateUser(@PathVariable Long id, @RequestBody UserUpdateVO updateVO) {return userService.updateUser(id, updateVO);
}
  1. @DeleteMapping
    适用场景
  • 删除资源
  • 资源回收站操作
// 示例:删除商品
@DeleteMapping("/products/{sku}")
public void deleteProduct(@PathVariable String sku) {productService.deleteBySku(sku);
}
  1. @PathVariable
    适用场景
  • RESTful风格URL中的资源定位
  • 需要强关联资源ID的操作
// 示例:电商商品详情页
@GetMapping("/products/{sku}")
public Product getProduct(@PathVariable String sku) {return productService.getProductBySku(sku);
}
  1. @RequestParam
    适用场景
  • 分页查询参数(page/size)
  • 筛选条件(时间范围、状态过滤)
  • 非必需参数传递
// 示例:带过滤条件的分页查询
@GetMapping("/orders")
public Page<Order> searchOrders(@RequestParam(required = false) LocalDate startDate,@RequestParam(required = false) LocalDate endDate,@RequestParam(defaultValue = "0") int page) {return orderService.searchOrders(startDate, endDate, page);
}

三、JSON数据处理注解

1. @RequestBody

作用:将请求体中的JSON数据绑定到Java对象

适用场景

  • POST/PUT请求中接收复杂结构数据
  • 前端表单提交JSON格式数据
  • 微服务间接口调用参数传递
// 示例:创建订单
@PostMapping("/orders")
public Order createOrder(@RequestBody OrderCreateVO createVO) {return orderService.createOrder(createVO);
}

2. @ResponseBody

作用:将方法返回值序列化为JSON(@RestController中已默认启用)

特殊使用场景

  • 在@Controller类中需要单个方法返回JSON时
  • 混合返回视图和API的场景
// 示例:传统Controller中的API方法
@Controller
public class HybridController {@ResponseBody@GetMapping("/api/status")public Map<String, Object> getSystemStatus() {return monitorService.getStatus();}
}

3. JSON处理注意事项

  • 需要添加Jackson依赖(Spring Boot已默认包含)
  • 日期格式建议统一处理:
# application.yml
spring:jackson:date-format: yyyy-MM-dd HH:mm:sstime-zone: GMT+8
  • 使用@JsonIgnore忽略敏感字段:
public class User {@JsonIgnoreprivate String password;  // 不序列化到JSON
}

4. 最佳实践建议

  1. RESTful设计规范

    • GET:查询
    • POST:创建
    • PUT:全量更新
    • PATCH:部分更新
    • DELETE:删除
  2. 参数选择原则

    • 资源标识用@PathVariable
    • 可选参数用@RequestParam
    • 复杂对象用@RequestBody
  3. JSON处理技巧

    • 使用DTO/VO对象隔离实体类
    • 字段脱敏处理(@JsonIgnore)
    • 统一响应格式(Result包装类)
// 统一响应示例
public class Result<T> {private int code;private String message;private T data;// 构造方法省略...
}@GetMapping("/users/{id}")
public Result<User> getUser(@PathVariable Long id) {return Result.success(userService.getUserById(id));
}

通过合理组合这些注解,可以:

  1. 构建清晰的API端点
  2. 实现安全的参数绑定
  3. 处理复杂数据结构
  4. 保持代码可维护性

实际开发中建议结合Swagger等API文档工具,实时验证注解配置效果。


四、依赖注入相关

1. @Autowired

作用:自动装配Bean,推荐结合构造函数使用。

@Service
public class UserService {private final UserRepository userRepository;@Autowiredpublic UserService(UserRepository userRepository) {this.userRepository = userRepository;}
}

2. 组件标识注解

  • @Service:业务层组件
  • @Repository:数据访问层组件
  • @Component:通用组件
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
}

五、配置相关注解

1. @Configuration & @Bean

作用:声明配置类并创建Bean实例。

@Configuration
public class AppConfig {@Beanpublic PasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder();}
}

2. @Value

作用:注入配置文件属性。

@Value("${app.page.size:10}")
private int defaultPageSize;

3. @ConfigurationProperties

作用:批量绑定配置属性到对象。

@ConfigurationProperties(prefix = "app.redis")
@Data
public class RedisConfig {private String host;private int port;private String password;
}

六、条件化配置

1. @ConditionalOnProperty

作用:根据配置决定是否创建Bean。

@Bean
@ConditionalOnProperty(name = "app.cache.enabled", havingValue = "true")
public CacheManager cacheManager() {return new RedisCacheManager();
}

2. @Profile

作用:指定环境激活的配置。

@Bean
@Profile("dev")
public DataSource devDataSource() {// 开发环境数据源配置
}

总结

Spring Boot通过丰富的注解体系,实现了约定优于配置的开发理念。熟练掌握这些注解能够:

  1. 快速构建RESTful API
  2. 实现优雅的依赖注入
  3. 灵活管理应用配置
  4. 按需启用功能模块

建议开发者结合官方文档和实际项目实践,逐步掌握更高级的注解使用技巧。Spring Boot的注解体系就像乐高积木,合理组合能搭建出高效可靠的企业级应用。


相关资源

  • Spring Boot官方文档
  • Spring注解编程模型

希望这篇博客能帮助您系统掌握Spring Boot的核心注解!如有疑问欢迎留言讨论。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/903247.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TRO再添新案 TME再拿下一热门IP,涉及Paddington多个商标

4月2日和4月8日&#xff0c;TME律所代理Paddington & Company Ltd.对热门IP Paddington Bear帕丁顿熊的多类商标发起维权&#xff0c;覆盖文具、家居用品、毛绒玩具、纺织用品、游戏、电影、咖啡、填充玩具等领域。跨境卖家需立即排查店铺内的相关产品&#xff01; 案件基…

经验分享-上传ios的ipa文件

.ipa格式的二进制文件&#xff0c;是打包后生成的文件&#xff0c;无论我们是放上去testflight测试还是正式上传到app store&#xff0c;都需要先上传到苹果开发者中心的app store connect上的构建版本上。 在app store connect上&#xff0c;上传构建版本的功能&#xff0c;它…

docker(3) -- 图形界面

1. 前言 在wsl(8) – 图形界面文章中介绍了wsl2默认是支持图形界面的&#xff0c;现在我们尝试下在docker中运行gui程序试试看。 2. x11-apps 启动一个docker&#xff0c;安装一些gui小程序&#xff0c;然后运行&#xff0c;发现会失败。ubuntu_base详见文章wsl(6) – 安装d…

Docker容器跑定时任务脚本

最近搞了一个Docker容器跑脚本&#xff0c;想设置一个定时任务&#xff0c;每天8点运行一次&#xff0c;结果死活不成功。排查了一天&#xff0c;有一点当局者迷了&#xff0c;明明时间是对的&#xff0c;明明时区是对的&#xff0c;定时任务也是启动的&#xff0c;它就是不执行…

【Linux】什么是完全限定域名

FQDN 是 “完全限定域名” (Fully Qualified Domain Name) 的缩写。 FQDN 是一个互联网上特定计算机或主机的完整且唯一的域名。它详细说明了该主机在域名系统 (DNS) 层级结构中的确切位置。 一个 FQDN 通常由以下几个部分组成&#xff0c;从左到右依次是&#xff1a; 主机名…

小结:BFD

*BFD&#xff08;双向转发检测&#xff0c;Bidirectional Forwarding Detection&#xff09;是一种快速、轻量级的故障检测机制&#xff0c;用于检测网络中两点之间的连通性。它广泛应用于各种场景 1. 检测 IP 链路 应用场景&#xff1a; BFD 用于检测两台设备之间的 IP 层连…

配置Spark历史服务器,轻松查看任务记录

在大数据处理中&#xff0c;Spark是一个强大的分布式计算框架。但当Spark服务重启后&#xff0c;之前的运行记录就会消失&#xff0c;给我们排查问题和分析任务执行情况带来不便。这时&#xff0c;配置Spark历史服务器就显得尤为重要&#xff0c;它能帮助我们保存和查看历史任务…

(六)RestAPI 毛子(外部导入打卡/游标分页/Refit/Http resilience/批量提交/Quartz后台任务/Hateoas Driven)

文章目录 项目地址一、外部导入打卡功能1.1 创建实体1. Entry实体2. EntryImport实体3. 添加数据库配置4. 创建表 1.2 创建DTOs1.3 创建GetEnties Controller 二、游标分页2.1 创建所需要的DTOs1. 创建游标分页的请求参数2. 创建CollectionResponse3. 添加游标编码和解码的DTO …

Node.js CSRF 保护指南:示例及启用方法

解释 CSRF 跨站请求伪造 (CSRF/XSRF) 是一种利用用户权限劫持会话的攻击。这种攻击策略允许攻击者通过诱骗用户以攻击者的名义提交恶意请求,从而绕过我们的安全措施。 CSRF 攻击之所以可能发生,是因为两个原因。首先,CSRF 攻击利用了用户无法辨别看似合法的 HTML 元素是否…

Flink介绍——实时计算核心论文之Dataflow论文总结

数据流处理的演变与 Dataflow 模型的革新 在大数据处理领域&#xff0c;流式数据处理系统的发展历程充满了创新与变革。从早期的 S4 到 Storm&#xff0c;再到 MillWheel&#xff0c;每一个系统都以其独特的方式推动了技术的进步。S4 以其无中心架构和 PE&#xff08;Processi…

Arduino 入门学习笔记(五):KEY实验

Arduino 入门学习笔记&#xff08;五&#xff09;&#xff1a;KEY实验 开发板&#xff1a;正点原子ESP32S3 例程源码在文章顶部可免费下载&#xff08;审核中…&#xff09; 1. GPIO 输入功能使用 1.1 GPIO 输入模式介绍 在上一文章中提及到 pinMode 函数&#xff0c; 要对…

Centos9安装docker

1. 卸载docker 查看是否安装了docker yum list | grep docker卸载老版本docker&#xff0c;拷贝自官网 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine卸载新版本…

Pgvector+R2R搭建RAG知识库

背景 R2R是一个采用Python编写的开源AI RAG框架项目&#xff0c;与PostgreSQL技术栈集成度高&#xff0c;运行需求资源少&#xff08;主要是本人的Macbook air m1内存只有8G&#xff09;的特点&#xff0c;对部署本地私有化化AI RAG应用友好。 Resource Recommendations Whe…

go中redis使用的简单介绍

目录 一、Redis 简介 二、Go中Redis的使用 1. 安装Go Redis包 2. 单机模式 连接示例 3. 哨兵模式 依赖 连接示例 三、Redis集群 1. 集群模式 集群部署 部署结构 使用redis-cli创建集群 连接示例 四、常用数据结构与操作 1. 字符串&#xff08;String&#xff0…

北京工业大学25计专上岸经验分享

1.个人情况介绍 本科就读于河北双非&#xff0c;专业为计算机科学与技术&#xff0c;四级三次498&#xff0c;六级两次460&#xff0c;拿过几次校级奖学金&#xff0c;竞赛经历有蓝桥杯国三、数学竞赛省二。本科成绩排名靠前&#xff0c;保研保7排8&#xff0c;遗憾选择考研继…

在 Ubuntu 24.04 系统上安装和管理 Nginx

1、安装Nginx 在Ubuntu 24.04系统上安装Nginx&#xff0c;可以按照下面的步骤进行&#xff1a; 1.1、 更新系统软件包列表 在安装新软件之前&#xff0c;需要先更新系统的软件包列表&#xff0c;确保获取到最新的软件包信息。打开终端&#xff0c;执行以下命令&#xff1a; …

HarmonyOS4+NEXT星河版入门与项目实战(26)-----版本控制与代码托管

引言 随着移动应用开发技术的不断进步,华为推出的鸿蒙操作系统(HarmonyOS)以及其配套的集成开发环境DevEco Studio逐渐成为开发者关注的焦点。对于新手开发者来说,掌握版本控制和代码托管不仅是提高工作效率的关键,也是团队协作的重要基础。本文将介绍如何在使用DevEco S…

利用Arcgis自己绘制shp文件

1.选择自己想要创建的shp文件的位置 我是直接创建在连接文件夹中 2.右键-新建-shp 3.设置名称、要素类型、空间参考 4、点击创建要素 5、右侧选择图层、创建面 6、开始绘制&#xff0c;双击任意位置结束绘制 之后可以改一下shp文件的名字

【C/C++】深入理解指针(六)

文章目录 深入理解指针(六)1.sizeof和strlen的对比1.1 sizeof1.2 strlen1.3 sizeof和strlen的对⽐ 2.数组和指针笔试题解析2.1 ⼀维数组2.2 字符数组代码1&#xff1a;代码2&#xff1a;代码3&#xff1a;代码4&#xff1a;代码5&#xff1a;代码6&#xff1a; 2.3 ⼆维数组 3.…

探索大语言模型(LLM):语言模型从海量文本中无师自通

文章目录 引言&#xff1a;当语言模型学会“自己教自己”一、自监督学习&#xff1a;从“无标签”中挖掘“有监督”信号二、语言模型的自监督训练范式&#xff1a;两大经典路径1. 掩码语言模型&#xff08;Masked Language Modeling, MLM&#xff09;——以BERT为例2. 自回归语…