Spring Boot 的核心注解

一、引言

Spring Boot 作为一种流行的 Java 开发框架,以其简洁高效的开发方式受到广泛关注。其中,核心注解在 Spring Boot 应用的开发中起着至关重要的作用。理解这些注解的含义和用法,对于充分发挥 Spring Boot 的优势至关重要。本文将深入剖析 Spring Boot 的核心注解。

二、@SpringBootApplication 注解

(一)功能概述

  1. 组合注解
    • @SpringBootApplication 是一个组合注解,它包含了 @Configuration、@EnableAutoConfiguration 和 @ComponentScan 三个注解的功能。
  2. 配置应用
    • 该注解用于标识一个 Spring Boot 应用的主配置类,告诉 Spring Boot 框架如何进行自动配置和组件扫描。

(二)用法详解

  1. 定义主类
    • 在 Spring Boot 应用中,通常会创建一个主类,并使用 @SpringBootApplication 注解进行标识。这个主类通常包含一个 main 方法,用于启动应用程序。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class MyApplication {public static void main(String[] args) {SpringApplication.run(MyApplication.class, args);}
}

  1. 自动配置

    • @SpringBootApplication 注解会触发 Spring Boot 的自动配置机制。Spring Boot 会根据项目中引入的依赖和类路径中的内容,自动配置应用程序所需的各种组件和配置。
  2. 组件扫描

    • 该注解还会启动组件扫描功能,自动扫描主类所在的包及其子包中的所有带有 @Component、@Service、@Repository、@Controller 等注解的类,并将它们注册为 Spring 容器中的 Bean。

三、@Configuration 注解

(一)功能介绍

  1. 定义配置类
    • @Configuration 注解用于标识一个类为 Spring 的配置类。在配置类中,可以使用 @Bean 注解定义 Bean,并进行各种配置。
  2. 替代 XML 配置
    • 随着 Spring 的发展,越来越多的开发者倾向于使用基于 Java 的配置方式,而 @Configuration 注解就是实现这种配置方式的关键。

(二)用法示例

  1. 定义 Bean
    • 在配置类中,可以使用 @Bean 注解定义 Bean。例如,定义一个名为 myService 的 Bean:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;@Configuration
public class AppConfig {@Beanpublic MyService myService() {return new MyServiceImpl();}
}

  1. 导入其他配置类
    • 可以使用 @Import 注解导入其他配置类,实现配置的模块化。例如:
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;@Configuration
@Import(AnotherConfig.class)
public class MainConfig {
}

四、@EnableAutoConfiguration 注解

(一)自动配置原理

  1. 依赖分析
    • @EnableAutoConfiguration 注解会根据项目中引入的依赖,自动配置应用程序所需的各种组件。例如,如果项目中引入了 Spring Data JPA 的依赖,Spring Boot 会自动配置数据库连接和 JPA 相关的组件。
  2. 排除特定自动配置
    • 有时候,可能需要排除某些自动配置。可以使用 @SpringBootApplication 的 exclude 属性来排除特定的自动配置类。例如:
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class MyApplication {public static void main(String[] args) {SpringApplication.run(MyApplication.class, args);}
}

(二)使用场景

  1. 快速开发
    • 在快速开发过程中,@EnableAutoConfiguration 注解可以大大减少配置的工作量,提高开发效率。
  2. 集成第三方库
    • 当集成第三方库时,Spring Boot 的自动配置功能可以自动配置与该库相关的组件,使得集成更加简单快捷。

五、@ComponentScan 注解

(一)扫描机制

  1. 包扫描
    • @ComponentScan 注解用于指定 Spring 容器进行组件扫描的包路径。默认情况下,它会扫描主类所在的包及其子包中的所有带有 @Component、@Service、@Repository、@Controller 等注解的类,并将它们注册为 Spring 容器中的 Bean。
  2. 自定义扫描路径
    • 可以通过 basePackages 属性指定自定义的扫描路径。例如:
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;@Configuration
@ComponentScan(basePackages = {"com.example.myapp.service", "com.example.myapp.repository"})
public class AppConfig {
}

(二)与其他注解的配合

  1. 与 @Controller、@Service、@Repository 等注解配合
    • @ComponentScan 注解与这些注解配合使用,可以实现自动注册 Bean 的功能。例如,当一个类被标注为 @Service 时,@ComponentScan 注解会将其扫描并注册为 Spring 容器中的一个服务 Bean。
  2. 与 @Configuration 注解配合
    • 在配置类中,通常会使用 @ComponentScan 注解来指定组件扫描的范围,以便将其他带有注解的类注册为 Bean。

六、@Autowired 注解

(一)依赖注入原理

  1. 自动装配
    • @Autowired 注解用于实现依赖注入。当一个类的字段、构造函数或方法被标注为 @Autowired 时,Spring 容器会自动将匹配的 Bean 注入到该字段、构造函数或方法中。
  2. 按类型匹配
    • Spring 容器会根据 Bean 的类型进行匹配。如果有多个相同类型的 Bean,还可以使用 @Qualifier 注解指定具体要注入的 Bean 的名称。

(二)用法示例

  1. 字段注入
    • 在类的字段上使用 @Autowired 注解,实现字段的自动注入。例如:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class MyService {@Autowiredprivate MyRepository myRepository;public void doSomething() {// 使用 myRepository}
}

  1. 构造函数注入
    • 在构造函数上使用 @Autowired 注解,实现构造函数的自动注入。例如:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class MyService {private final MyRepository myRepository;@Autowiredpublic MyService(MyRepository myRepository) {this.myRepository = myRepository;}public void doSomething() {// 使用 myRepository}
}

  1. 方法注入
    • 在方法上使用 @Autowired 注解,实现方法的自动注入。例如:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class MyService {private MyRepository myRepository;@Autowiredpublic void setMyRepository(MyRepository myRepository) {this.myRepository = myRepository;}public void doSomething() {// 使用 myRepository}
}

七、@Value 注解

(一)属性注入

  1. 从配置文件中获取值
    • @Value 注解可以用于从配置文件(如 application.properties 或 application.yml)中获取属性值,并注入到字段、构造函数参数或方法参数中。
  2. 表达式支持
    • 还可以使用 SpEL(Spring Expression Language)表达式来获取更复杂的值。例如:
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;@Service
public class MyService {@Value("${my.property}")private String myProperty;@Value("#{T(java.lang.Math).random() * 100}")private int randomNumber;public void doSomething() {// 使用 myProperty 和 randomNumber}
}

(二)使用场景

  1. 动态配置
    • 在需要根据不同环境进行动态配置的情况下,@Value 注解非常有用。可以将配置文件中的属性值注入到 Bean 中,实现灵活的配置。
  2. 参数化构造函数
    • 可以在构造函数参数上使用 @Value 注解,实现参数化的构造函数,根据配置文件中的值来创建 Bean。

八、@RequestMapping 注解

(一)处理 HTTP 请求

  1. 映射请求路径
    • @RequestMapping 注解用于将一个方法映射到特定的 HTTP 请求路径上。它可以用在类级别和方法级别上,用于定义控制器类和方法的请求映射。
  2. 支持多种 HTTP 方法
    • 可以通过 value 属性指定请求路径,通过 method 属性指定支持的 HTTP 方法(如 GET、POST、PUT、DELETE 等)。

(二)用法示例

  1. 类级别映射
    • 在控制器类上使用 @RequestMapping 注解,定义类级别的请求映射。例如:
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/api")
public class MyController {// 方法级别的请求映射将在此基础上进行
}

  1. 方法级别映射
    • 在控制器方法上使用 @RequestMapping 注解,定义具体的请求映射。例如:
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/api")
public class MyController {@RequestMapping(value = "/users", method = RequestMethod.GET)public List<User> getUsers() {// 返回用户列表}
}

九、@RestController 注解

(一)构建 RESTful API

  1. 标识控制器
    • @RestController 注解是 @Controller 和 @ResponseBody 的组合注解。它用于标识一个控制器类,该类中的方法将返回 JSON、XML 或其他格式的响应数据,用于构建 RESTful API。
  2. 自动序列化响应数据
    • 当一个方法被标注为 @RestController 注解的类中的方法返回一个对象时,Spring Boot 会自动将该对象序列化为 JSON 或其他格式的响应数据,并返回给客户端。

(二)与其他注解的配合

  1. 与 @RequestMapping 注解配合
    • @RestController 注解通常与 @RequestMapping 注解一起使用,用于定义 RESTful API 的请求映射和响应数据。
  2. 与 @Service、@Repository 等注解配合
    • 在构建复杂的应用程序时,@RestController 注解可以与其他注解(如 @Service、@Repository)配合使用,实现业务逻辑和数据访问的分离。

十、实际案例分析

(一)案例背景

假设有一个简单的博客应用,需要实现文章的管理功能,包括创建、读取、更新和删除文章。

(二)技术选型

  1. 使用 Spring Boot 构建应用
    • 选择 Spring Boot 作为开发框架,利用其快速开发、自动配置等优势。
  2. 数据库选择
    • 选择一个关系型数据库(如 MySQL)来存储文章数据。
  3. 前端框架选择
    • 可以选择一个前端框架(如 Vue.js 或 React)来构建用户界面,与后端的 Spring Boot 应用进行交互。

(三)核心注解的应用

  1. @SpringBootApplication 注解
    • 在主类上使用 @SpringBootApplication 注解,标识这是一个 Spring Boot 应用的主配置类。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class BlogApplication {public static void main(String[] args) {SpringApplication.run(BlogApplication.class, args);}
}

  1. @Configuration 注解
    • 创建一个配置类,使用 @Configuration 注解标识。在这个配置类中,可以定义 Bean 和进行其他配置。
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DriverManagerDataSource;@Configuration
public class AppConfig {@Beanpublic JdbcTemplate jdbcTemplate() {DriverManagerDataSource dataSource = new DriverManagerDataSource();dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");dataSource.setUrl("jdbc:mysql://localhost:3306/blogdb");dataSource.setUsername("root");dataSource.setPassword("password");return new JdbcTemplate(dataSource);}
}

  1. @Autowired 注解
    • 在服务类和控制器类中,使用 @Autowired 注解进行依赖注入。例如,在文章服务类中注入 JdbcTemplate:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class ArticleService {private final JdbcTemplate jdbcTemplate;@Autowiredpublic ArticleService(JdbcTemplate jdbcTemplate) {this.jdbcTemplate = jdbcTemplate;}public void createArticle(Article article) {// 使用 jdbcTemplate 执行数据库插入操作}public Article getArticleById(int id) {// 使用 jdbcTemplate 执行数据库查询操作}// 其他方法
}

  1. @RequestMapping 注解和 @RestController 注解
    • 在控制器类中,使用 @RequestMapping 注解和 @RestController 注解定义 RESTful API 的请求映射。例如:
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/articles")
public class ArticleController {private final ArticleService articleService;@Autowiredpublic ArticleController(ArticleService articleService) {this.articleService = articleService;}@RequestMapping(method = RequestMethod.POST)public void createArticle(Article article) {articleService.createArticle(article);}@RequestMapping(value = "/{id}", method = RequestMethod.GET)public Article getArticleById(@PathVariable int id) {return articleService.getArticleById(id);}// 其他方法
}

(四)效果评估

  1. 开发效率
    • 通过使用 Spring Boot 的核心注解,大大提高了开发效率。自动配置和依赖注入功能减少了手动配置的工作量,使得开发过程更加快捷。
  2. 代码可读性和可维护性
    • 注解的使用使得代码更加清晰易读,易于理解和维护。例如,通过 @RequestMapping 注解和 @RestController 注解,可以很容易地看出控制器类的作用和请求映射关系。
  3. 功能实现
    • 成功实现了博客应用的文章管理功能,包括创建、读取、更新和删除文章。通过 RESTful API 的方式,使得前端可以方便地与后端进行交互。

十一、总结

Spring Boot 的核心注解在开发过程中起着至关重要的作用。@SpringBootApplication、@Configuration、@EnableAutoConfiguration、@ComponentScan、@Autowired、@Value、@RequestMapping 和 @RestController 等注解分别在应用的配置、自动配置、组件扫描、依赖注入、属性注入、请求映射和构建 RESTful API 等方面发挥着重要作用。通过深入理解这些注解的功能和用法,并结合实际案例进行应用,可以提高开发效率,增强代码的可读性和可维护性,实现高效的 Java 开发。

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

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

相关文章

Java版——设计模式笔记

Java版——设计模式笔记 设计模式的分类 创建型模式&#xff08;Creational&#xff09;&#xff1a;关注对象的实例化过程&#xff0c;包括了如何实例化对象、隐藏对象的创建细节等。常见的创建型模式有单例模式、工厂模式、抽象工厂模式等。结构型模式&#xff08;Structur…

多语言电商系统的多语言设计机制

在全球化电商市场中&#xff0c;跨语言沟通是提升用户体验和扩大市场份额的关键。为了满足不同语言用户的需求&#xff0c;构建一个支持多语言的电商系统已成为企业扩展国际市场的重要步骤。多语言电商系统需要能够根据用户的语言偏好自动显示内容&#xff0c;同时保证翻译的准…

【Steam登录】protobuf协议逆向 | 续

登录接口&#xff1a; ‘https://api.steampowered.com/IAuthenticationService/BeginAuthSessionViaCredentials/v1’ 精准定位&#xff0c;打上条件断点 this.CreateWebAPIURL(t) ‘https://api.steampowered.com/IAuthenticationService/BeginAuthSessionViaCredentials/v1…

Python | Leetcode Python题解之第556题下一个更大元素III

题目&#xff1a; 题解&#xff1a; class Solution:def nextGreaterElement(self, n: int) -> int:x, cnt n, 1while x > 10 and x // 10 % 10 > x % 10:cnt 1x // 10x // 10if x 0:return -1targetDigit x % 10x2, cnt2 n, 0while x2 % 10 < targetDigit:c…

Python——数列1/2,2/3,3/4,···,n/(n+1)···的一般项为Xn=n/(n+1),当n—>∞时,判断数列{Xn}是否收敛

没注释的源代码 from sympy import * n symbols(n) s n/(n1) print(数列的极限为&#xff1a;,limit(s,n,oo))

Java基础——类和对象的定义链表的创建,输出

目录 什么是类&#xff1f; 什么是对象? 如何创建链表&#xff1f; 尾插法&#xff1a; 头插法&#xff1a; 输出链表的长度 输出链表的值 什么是类&#xff1f; 创建Java程序必须创建一个类class. .java程序需要经过javac指令将文件翻译为.class字节码文件&#xff0c…

python代码打包exe文件(可执行文件)

一、exe打包 1、构建虚拟环境 conda create -n env_name python3.8 #env_name,python根据自己需求修改2、保存和安装项目所需的所有库 pip freeze > requirements.txt3、虚拟环境安装项目包、库 pip install -r requirements.txt4、安装pyinstaller pip install pyinst…

【Linux】冯诺依曼体系结构

目录 一、冯诺依曼体系结构二、冯诺依曼体系结构的基本组成三、关于冯诺依曼体系结构的一些问题结尾 一、冯诺依曼体系结构 冯诺依曼体系结构&#xff0c;也称为普林斯顿结构&#xff0c;是现代计算机设计的基础框架。这一体系结构由数学家冯诺依曼在20世纪40年代提出&#xf…

图像信号处理器(ISP,Image Signal Processor)详解

简介&#xff1a;个人学习分享&#xff0c;如有错误&#xff0c;欢迎批评指正。 图像信号处理器&#xff08;ISP&#xff0c;Image Signal Processor&#xff09; 是专门用于处理图像信号的硬件或处理单元&#xff0c;广泛应用于图像传感器&#xff08;如 CMOS 或 CCD 传感器&a…

英飞凌Aurix2G TC3XX GPT12模块详解

英飞凌Aurix2G TC3XX GPT12模块详解 本文主要介绍英飞凌 Aurix2G TC3XX系列芯片GPT12模块硬件原理、MCAL相关配置和部分代码实现。 文章目录 英飞凌Aurix2G TC3XX GPT12模块详解1 模块介绍2 功能介绍2.1 结构2.2 独立运行模式2.2.1 定时器模式2.2.2 门控定时器模式2.2.3 计数…

Python小白学习教程从入门到入坑------第二十九课 访问模式(语法进阶)

目录 一、访问模式 1.1 r 1.2 w 1.3 1.3.1 r 1.3.2 w 1.3.3 a 1.4 a 一、访问模式 模式可做操作若文件不存在是否覆盖r只能读报错-r可读可写报错是w只能写创建是w可读可写创建是a只能写创建否&#xff0c;追加写a可读可写创建否&#xff0c;追加写 1.1 r r&…

【Linux】Linux入门实操——vim、目录结构、远程登录、重启注销

一、Linux 概述 1. 应用领域 服务器领域 linux在服务器领域是最强的&#xff0c;因为它免费、开源、稳定。 嵌入式领域 它的内核最小可以达到几百KB, 可根据需求对软件剪裁&#xff0c;近些年在嵌入式领域得到了很大的应用。 主要应用&#xff1a;机顶盒、数字电视、网络…

十三:java web(5)-- Spring数据持久层

目录 Spring 数据持久层 1. Spring 与 JDBC 1.1 使用 Spring 管理数据库连接 1.1.2 Apache Commons DBCP 基于配置文件xml 使用 1.1.3 Apache Commons DBCP 基于配置类使用 1.1.4 HikariCP 基于配置文件xml 使用 推荐使用 Spring Boot 默认连接池 1.1.5 HikariCP 基于配置…

uniApp之uni-file-picker使用踩坑

标题党~也不算坑吧 就是初体验 上传是需要存储一下子的&#xff0c;我以为uniApp是自己免费开的服务给大家中转使用&#xff0c;就没管这个事&#xff0c;但是官网是这么说的&#xff1a; 就我是怎么发现的&#xff0c;使用了一段时间后&#xff0c;上传的图片都裂了&#xff…

开源竞争-大数据项目期末考核

开源竞争&#xff1a; 自己没有办法完全掌握技术的时候就开源这个技术&#xff0c;培养出更多的技术依赖&#xff0c;让更多人完善你的技术&#xff0c;那么这不就是在砸罐子吗&#xff1f;一个行业里面总会有人砸罐子的&#xff0c;你不如先砸还能听个想。 客观现实&#xf…

Flutter3.22.2中SliverAppBar设置背景色滑动显示颜色错误

在使用Flutter项目开发中&#xff0c;可能会有页面需要滑动收起标题栏的效果&#xff0c;一般都会使用SliverAppBar来实现&#xff0c;当项目的Flutter的SDK版本升级到3.4后&#xff0c;发现使用了SliverAppBar的页面&#xff0c;在滑动过程中&#xff0c;标题栏和状态栏的颜色…

SpringBoot3中swagger无法使用

前言 springboot 3开始javax包改成了jakarta&#xff0c;而swagger-oas等包中依然使用的是javax&#xff0c;所以报错。另外springfox已经停止更新有段时间了&#xff0c;并且不支持OpenAPI 3标准&#xff0c;升级Springboot 3.0以后会有更多问题暴露出来。而SpringBoot 3只支…

使用docker安装zlmediakit服务(zlm)

zlmediakit安装 zlmediakit安装需要依赖环境和系统配置&#xff0c;所以采用docker的方式来安装不容易出错。 docker pull拉取镜像(最新) docker pull zlmediakit/zlmediakit:master然后先运行起来 sudo docker run -d -p 1935:1935 -p 80:80 -p 8554:554 -p 10000:10000 -p …

第九周预习报告

文章目录 密码系统设计第九周预习报告学习内容AI 对学习内容的总结&#xff08;1分&#xff09;要求总结 对 AI 总结的反思与补充&#xff08;2分&#xff09;反思与补充 补充内容反思学习思维导图&#xff08;2分&#xff09;要求思维导图代码导图 基于 AI 的学习&#xff08;…

GB/T 43206—2023信息安全技术信息系统密码应用测评要求(五)

文章目录 附录AA.1 概述A.2 密钥产生A.3 密钥分发A.4 密钥存储A.5 密钥使用A.6 密钥更新A.7 密钥归档A. 8 密钥撤销A.9 密钥备份A.10 密钥恢复A.11 密钥销毁 附录B附录C 附录A A.1 概述 密钥管理对于保证密钥全生存周期的安全性至关重要 ,可以保证密钥(除公开密钥外) 不被非授…