>Java >java지도 시간 >Spring Boot의 25개 핵심 주석은 무엇입니까?

Spring Boot의 25개 핵심 주석은 무엇입니까?

hzc
hzc원래의
2020-06-22 11:55:163535검색

Spring Boot의 25개 핵심 주석은 무엇입니까?

Spring Boot의 25개 핵심 주석

1. @SpringBootApplication

이는 Spring Boot의 메인 클래스에서 이를 식별하는 데 사용됩니다. Spring Boot의 다양한 기능을 활성화하는 데 사용되는 Spring Boot 애플리케이션입니다.

실제로 이 주석은 @SpringBootConfiguration, @EnableAutoConfiguration@ComponentScan 세 가지 주석을 조합한 것입니다. 세 개의 주석이 @SpringBootApplication 주석을 대체합니다. @SpringBootConfiguration@EnableAutoConfiguration@ComponentScan这三个注解的组合,也可以用这三个注解来代替 @SpringBootApplication 注解。

2、@EnableAutoConfiguration

允许 Spring Boot 自动配置注解,开启这个注解之后,Spring Boot 就能根据当前类路径下的包或者类来配置 Spring Bean。

如:当前类路径下有 Mybatis 这个 JAR 包,MybatisAutoConfiguration 注解就能根据相关参数来配置 Mybatis 的各个 Spring Bean。

3、@Configuration

这是 Spring 3.0 添加的一个注解,用来代替 applicationContext.xml 配置文件,所有这个配置文件里面能做到的事情都可以通过这个注解所在类来进行注册。

4、@SpringBootConfiguration

这个注解就是 @Configuration 注解的变体,只是用来修饰是 Spring Boot 配置而已,或者可利于 Spring Boot 后续的扩展。

5、@ComponentScan

这是 Spring 3.1 添加的一个注解,用来代替配置文件中的 component-scan 配置,开启组件扫描,即自动扫描包路径下的 @Component 注解进行注册 bean 实例到 context 中。

前面 5 个注解可以在这篇文章《Spring Boot 最核心的 3 个注解详解》中了解更多细节的。

6、@Conditional

这是 Spring 4.0 添加的新注解,用来标识一个 Spring Bean 或者  Configuration 配置文件,当满足指定的条件才开启配置。

7、@ConditionalOnBean

组合 @Conditional 注解,当容器中有指定的 Bean 才开启配置。

8、@ConditionalOnMissingBean

组合 @Conditional 注解,和 @ConditionalOnBean 注解相反,当容器中没有指定的 Bean 才开启配置。

9、@ConditionalOnClass

组合 @Conditional 注解,当容器中有指定的 Class 才开启配置。

10、@ConditionalOnMissingClass

组合 @Conditional 注解,和 @ConditionalOnMissingClass 注解相反,当容器中没有指定的 Class 才开启配置。

11、@ConditionalOnWebApplication

组合 @Conditional 注解,当前项目类型是 WEB 项目才开启配置。

当前项目有以下 3 种类型。

enum Type {    /**     * Any web application will match.     */    ANY,    /**     * Only servlet-based web application will match.     */    SERVLET,    /**     * Only reactive-based web application will match.     */    REACTIVE}

12、@ConditionalOnNotWebApplication

组合 @Conditional 注解,和 @ConditionalOnWebApplication 注解相反,当前项目类型不是 WEB 项目才开启配置。

13、@ConditionalOnProperty

组合 @Conditional 注解,当指定的属性有指定的值时才开启配置。

14、@ConditionalOnExpression

组合 @Conditional 注解,当 SpEL 表达式为 true 时才开启配置。

15、@ConditionalOnJava

组合 @Conditional 注解,当运行的 Java JVM 在指定的版本范围时才开启配置。

16、@ConditionalOnResource

组合 @Conditional 注解,当类路径下有指定的资源才开启配置。

17、@ConditionalOnJndi

组合 @Conditional 注解,当指定的 JNDI 存在时才开启配置。

18、@ConditionalOnCloudPlatform

组合 @Conditional 注解,当指定的云平台激活时才开启配置。

19、@ConditionalOnSingleCandidate

组合 @Conditional 注解,当指定的 class 在容器中只有一个 Bean,或者同时有多个但为首选时才开启配置。

20、@ConfigurationProperties

用来加载额外的配置(如 .properties 文件),可用在 @Configuration 注解类,或者@Bean 注解方法上面。

关于这个注解的用法可以参考《Spring Boot读取配置的几种方式》这篇文章。

21、@EnableConfigurationProperties

一般要配合 @ConfigurationProperties 注解使用,用来开启对@ConfigurationProperties

🎜🎜2. @EnableAutoConfiguration🎜🎜🎜🎜을 사용하면 Spring Boot에서 이 주석을 자동으로 구성할 수 있습니다. Spring Boot는 현재 클래스 경로의 패키지 또는 클래스를 기반으로 Spring Bean을 구성할 수 있습니다. 🎜🎜예: 현재 클래스 경로 아래에 Mybatis JAR 패키지가 있는 경우 MybatisAutoConfiguration 주석은 관련 매개변수에 따라 Mybatis의 각 Spring Bean을 구성할 수 있습니다. 🎜🎜🎜🎜3. @Configuration🎜🎜🎜🎜applicationContext.xml 구성 파일을 대체하기 위해 Spring 3.0에서 추가한 주석입니다. 이 구성 파일에서 수행할 수 있는 모든 작업은 이 주석이 있는 클래스를 통해 등록할 수 있습니다. . 🎜🎜🎜4. @SpringBootConfiguration🎜🎜🎜이 주석은 @Configuration 주석의 변형입니다. 이는 Spring Boot 구성을 수정하는 데만 사용되거나 Spring Boot의 후속 확장을 용이하게 할 수 있습니다. 🎜🎜🎜5. @ComponentScan🎜🎜🎜구성 파일의 컴포넌트 스캔 구성을 대체하고 컴포넌트 스캔을 활성화하기 위해 Spring 3.1에서 추가한 주석입니다. 즉, 패키지 경로 아래의 @Component 주석을 자동으로 스캔하여 빈 인스턴스. 🎜🎜이 문서 "Spring Boot의 3개 핵심 주석에 대한 자세한 설명"에서 처음 5개 주석에 대한 자세한 내용을 알아볼 수 있습니다. 🎜🎜🎜6. @Conditional🎜🎜🎜 이것은 Spring 4.0에서 추가된 새로운 주석입니다. 이는 Spring Bean 또는 구성 구성 파일을 식별하는 데 사용됩니다. 지정된 조건이 충족될 때만 구성이 활성화됩니다. 🎜🎜🎜7, @ConditionalOnBean🎜🎜🎜은 @Conditional 주석을 결합하고 컨테이너에 지정된 Bean이 있는 경우에만 구성이 활성화됩니다. 🎜🎜🎜8, @ConditionalOnMissingBean🎜🎜🎜은 @ConditionalOnBean 주석의 반대인 @Conditional 주석을 결합합니다. 구성은 지정되지 않은 경우에만 활성화됩니다. 컨테이너에 콩이 들어있습니다. 🎜🎜🎜9, @ConditionalOnClass🎜🎜🎜은 @Conditional 주석을 결합하고 컨테이너에 지정된 클래스가 있는 경우에만 구성이 활성화됩니다. 🎜🎜🎜10.@ConditionalOnMissingClass🎜🎜🎜는 @ConditionalOnMissingClass 주석과 반대되는 @Conditional 주석을 결합합니다. 구성은 지정되지 않은 경우에만 활성화됩니다. 컨테이너의 클래스입니다. 🎜🎜🎜11. @ConditionalOnWebApplication🎜🎜🎜은 @Conditional 주석을 결합합니다. 구성은 현재 프로젝트 유형이 WEB 프로젝트인 경우에만 활성화할 수 있습니다. 🎜🎜현재 3가지 유형의 프로젝트가 있습니다. 🎜
@AutoConfigureAfter(DataSourceAutoConfiguration.class)public class MybatisAutoConfiguration {
🎜🎜12, @ConditionalOnNotWebApplication🎜🎜🎜은 @ConditionalOnWebApplication 주석과 반대되는 @Conditional 주석을 결합합니다. 현재 프로젝트 유형은 이전의 WEB 프로젝트가 아닙니다. 구성이 활성화되었습니다. 🎜🎜🎜13.@ConditionalOnProperty🎜🎜🎜는 @Conditional 주석을 결합하며 지정된 속성에 지정된 값이 있는 경우에만 구성이 활성화됩니다. 🎜🎜🎜14, @ConditionalOnExpression🎜🎜🎜은 @Conditional 주석을 결합하고 SpEL 표현식이 true인 경우에만 구성이 활성화됩니다. 🎜🎜🎜15. @ConditionalOnJava🎜🎜🎜는 실행 중인 Java JVM이 지정된 버전 범위 내에 있을 때 구성을 활성화하기 위해 @Conditional 주석을 결합합니다. 🎜🎜🎜16. @ConditionalOnResource🎜🎜🎜는 @Conditional 주석을 결합합니다. 구성은 클래스 경로에 지정된 리소스가 있는 경우에만 활성화됩니다. 🎜🎜🎜17. @ConditionalOnJndi🎜🎜🎜는 지정된 JNDI가 존재할 때 구성을 활성화하기 위해 @Conditional 주석을 결합합니다. 🎜🎜🎜18, @ConditionalOnCloudPlatform🎜🎜🎜 조합 @Conditional 주석, 구성은 지정된 클라우드 플랫폼이 활성화된 경우에만 활성화됩니다. 🎜🎜🎜19, @ConditionalOnSingleCandidate🎜🎜🎜Combined @Conditional 주석, 구성은 지정된 클래스의 컨테이너에 Bean이 하나만 있거나 동시에 여러 Bean이 있는 경우에만 활성화됩니다. 선호됩니다. 🎜🎜🎜20. @ConfigurationProperties🎜🎜🎜는 @Configuration 주석이 달린 클래스 또는 @Bean에서 사용할 수 있는 추가 구성(예: .properties 파일)을 로드하는 데 사용됩니다. 주석이 달린 방법. 🎜🎜이 주석의 사용법은 "Spring Boot로 구성을 읽는 여러 가지 방법" 문서를 참조하세요. 🎜🎜🎜21. @EnableConfigurationProperties🎜🎜🎜는 일반적으로 @ConfigurationProperties 주석과 함께 사용되어 @ConfigurationProperties 주석 구성 Bean에 대한 지원을 활성화합니다. 🎜

22、@AutoConfigureAfter

用在自动配置类上面,表示该自动配置类需要在另外指定的自动配置类配置完之后。

如 Mybatis 的自动配置类,需要在数据源自动配置类之后。

@AutoConfigureAfter(DataSourceAutoConfiguration.class)public class MybatisAutoConfiguration {

23、@AutoConfigureBefore

这个和 @AutoConfigureAfter 注解使用相反,表示该自动配置类需要在另外指定的自动配置类配置之前。

24、@Import

这是 Spring 3.0 添加的新注解,用来导入一个或者多个 @Configuration 注解修饰的类,这在 Spring Boot 里面应用很多。

25、@ImportResource

这是 Spring 3.0 添加的新注解,用来导入一个或者多个 Spring  配置文件,这对 Spring Boot 兼容老项目非常有用,因为有些配置无法通过 Java Config 的形式来配置就只能用这个注解来导入。

推荐教程: 《java教程

위 내용은 Spring Boot의 25개 핵심 주석은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.