这个注解相当于三个注解的功能集成
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
// 以下三个注解是SpringBoot中非常重要的内容
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = {
@Filter( type = FilterType.CUSTOM, classes = {TypeExcludeFilter.class}),
@Filter( type = FilterType.CUSTOM, classes = {AutoConfigurationExcludeFilter.class}) })
public @interface SpringBootApplication {
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Configuration
public @interface SpringBootConfiguration {
}
可以看到上边的代码中,@SpringBootConfiguration 注解的上方还有一个@Configuration的注解内容,表示这个注解本质来说也就是一个Configuration,即这就是SpringBoot为什么不需要xml配置文件的原因,总的来说,这个注解允许了配置bean和导入其他的配置类的行为。
@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import({AutoConfigurationImportSelector.class})
public @interface EnableAutoConfiguration {
String ENABLED_OVERRIDE_PROPERTY = "spring.boot.enableautoconfiguration";
Class<?>[] exclude() default {};
String[] excludeName() default {};
}
这个注解总的来说就是为了解决自动装配的问题,即 启用Spring Boot的自动bean加载机制,具体的内容,后续再进行描述。
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
@Documented
@Repeatable(ComponentScans.class)
public @interface ComponentScan {
...
}
这个就是自动扫描包的注解配置,具体需要注意的点就是这段注释
* <p>Either {@link #basePackageClasses} or {@link #basePackages} (or its alias
* {@link #value}) may be specified to define specific packages to scan. If specific
* packages are not defined, scanning will occur from the package of the
* class that declares this annotation.
转译成中文的意思大概就是,如果注解上没有配置 basePackageClasses 或 basePackages, 则会默认扫描当前注解声明的类的包路径。
如下图所示,如果SpringBootApplication注解没有定义包路径scanBasePackages,则会自动默认扫描与Application.java这个类所属包下的内容。
默认的包结构及其作用
- 主程序Application.java放在根包,在其他类之上。
- @SpringBootApplication注解写在主程序上。
- Spring对类的扫描默认仅涵盖主程序所在的包及子包
注意: 如果定义了 scanBasePackageClasses 或 scanBasePackages,可能会导致启动类包路径下的bean无法被扫描到,所以启动类的包路径也要加入进去,避免出现无法正常扫描包的问题。
SpringBoot中建议放弃通过XML定义Spring应用程序,推荐在代码类上面通过@Configuration实现配置。如有需要,还可以通过@lmportResource来导入xml配置文件。
即通俗点来说,在SpringBoot项目中,最好不要使用xml的配置文件,而使用@Configuration定义相关的类,如果真的有需要,请使用@ImportResource来导入xml配置文件。
注:要使@Configuration生效,你需要将它写在SpringBoot入口程序类上面,或者使用@EnableAutoConfiguration或 @SpringBootApplication这两个注解来开启自动加载功能。
Spring应用程序可以通过属性文件,YAML文件,环境变量和命令行参数等方式的外部化参数配置
没有创建application.yml文件的时候使用这种方式
java -jar springboot-demo-1.0.0.jar --spring.profile.active="test"
java -jar springboot-demo1-1.0.0.jar --SPRING_APPLICATION_JSON="{\"spring.profiles.active\":\"dev\"}"
一般来说,我们创建一个SpringBoot项目,一般都有好几个yml文件,如:
- application.yml 主文件
- application-dev.yml 开发环境配置
- application-test.yml 测试环境配置
- application-prod.yml 生产环境配置
以上的几个配置文件分别是使用在不同的环境下的,但是我们可以通过修改application.yml的内容,来决定使用哪个文件,如下方所示:
![]()
这里表示使用的开发环境的配置文件。
SpringApplication springApplication = new SpringApplication(Example.class);
springApplication.setAdditionalProfiles();
Properties properties = new Properties();
properties.setProperty("name", "setDefaultProperties-tony");
springApplication.setDefaultProperties(properties);
springApplication.run(args);
profile是什么机制?
1.Spring配置文件提供的一种隔离应用程序配置的方法,使其仅在特定环境中可用。
2.可通过profile指定Bean的应用环境(如开发、测试、生产等环境)
3.可通过profile指定不同环境的配置参数值
如何指定profile
通过配置参数spring.profiles.active来指定应用启用的profiles。默认default
1.在环境变量中指定: jvm参数、命令行程序参数、application.properties中都可以
2.代码中指定: springApplication.setAdditionalProfiles("dev,test");
如何在开发中使用
1.Configuration类或者Bean定义方法上,都可以通过添加@Profile(" dev")注解,实现指定环境下生效。
2.配置文件中:<beans profile= "dev" ><bean …>…</bean></bean>
上述配置文件按优先级排列,排在上面的位置会覆盖优先级降低的配置。
SpringBoot支持两种配置文件的格式: .properites、.yml
yaml语法精简版说明:
list列表元素通过“-”表示
properites示例:
spring.datasource.username=test
方式一:
通过@Value("${my.name}")注解y将指定的参数配置注入到属性。
方式二:
注入Environment对象。
方式三:
通过注解@ConfigurationProperties(prefix = "my")
将注解加在指定的类上,spring会为实例对象的属性进行赋值,属性需有getters和setters方法。
如果觉得有收获就点个赞吧,更多知识,请点击关注查看我的主页信息哦~