注解
-
@Configuration
-
spring的配置的时候使用此注解
-
@Configuration(proxyBeanMethods=false)
配置为jdk动态代理,没有实现的接口所以false -
注意spring boot 2.2版本可以使用
proxyBeanMethods=false
-
代理模式spring会自动选择也可以直接使用
@Configuration
- 你不需要把所有的
@Configuration
东西都放在一个班级里(班级举例),@Import
注释可以用于导入额外的配置类。 -
或者,您可以使用
@ComponentScan
自动获取所有Spring组件,包括@Configuration
类。 -
@EnableAutoConfiguration
-
默认开启@SpringBootApplication包含,自动装配配置类
-
@EnableAutoConfiguration(exclude={排除的配置类.class})
-
如果发现正在应用您不需要的特定自动配置类,则可以使用exclude属性
@EnableAutoConfiguration
禁用 -
例如替换默认DataSourceAutoConfiguration.class 数据配置
-
@Import
-
导入的类必须是@Configuration配置类,
@Import
注释可以用于导入额外的配置类。 -
例如这个配置类获取另一个配置类消息
-
@ComponentScan
-
默认开启会扫描WebApplication类所属包,例如:WebApplication在com.cn下扫描com.cn
-
@Component
-
单例模式 自动装配Bean:在自动检测的组件的情况下将变为Spring bean
-
@Bean
-
单例模式 注册Bean:@Bean 需要在配置类中使用,即类上需要加上@Configuration注解
-
第三方库中的组件装配到你的应用中,在这种情况下,是没有办法在它的类上添加@Component注解的
-
@ImportResource
-
注释来加载配置文件例如:@ImportResource("classpath:test.xml")
项目启动控制台打印
//CommandLineRunner或ApplicationRunner
@Component
public class Test implements CommandLineRunner {
@Override
public void run(String... args) throws Exception {
System.out.println("----我想打印的内容为123----");
}
}
申请退出
- 每个都
SpringApplication
注册一个与JVM的关闭钩子,以确保ApplicationContext
在退出时正常关闭。可以使用所有标准的Spring生命周期回调(例如DisposableBean
接口或@PreDestroy
注释)。 - 此外,
org.springframework.boot.ExitCodeGenerator
如果bean 在SpringApplication.exit()
调用时希望返回特定的退出代码,则可以实现该接口。然后可以传递此退出代码System.exit()
以将其作为状态代码返回,如以下示例所示: -
@SpringBootApplication public class ExitCodeApplication { @Bean public ExitCodeGenerator exitCodeGenerator() { return () -> 42; } public static void main(String[] args) { System.exit(SpringApplication.exit(SpringApplication.run(ExitCodeApplication.class, args))); } }
Spring Boot 配置文件相关
-
配置随机值
-
my.secret=${random.value} my.number=${random.int} my.bignumber=${random.long} my.uuid=${random.uuid} my.number.less.than.ten=${random.int(10)} my.number.in.range=${random.int[1024,65536]}
自定义配置
-
@Getter @Setter @ConfigurationProperties(prefix = "project.security")//配置前缀 @EnableConfigurationProperties(SecurityProperties.class) public class SecurityProperties { // 免认证静态资源路径 private String[] anonResourcesUrl; //超时时间默认1小时 private Duration sessionTimeout = Duration.ofHours(1); //超时时间默认5分钟 private Duration redisTimeout = Duration.ofMinutes(5); //超时时间默认1小时 private int cookieTimeout = 60 * 60; //登录地址 private String loginUrl; //退出地址 private String logoutUrl; }
#自定义配置 project: security: #免认证静态资源路径 anon-resources-url: /error,/login,/logout,/other/** #登录地址 login-url: /login #退出地址 logout-url: /logout #一小时 session-timeout: PT1H #3600秒 cookie-timeout: 3600 #5分钟 redis-timeout: PT5M
读取配置文件信息 ( 以下静态方法不能读取)
-
public class Test { @Autowired private SecurityProperties securityProperties; @Value("${project.logout-url}") private String url; public void test() { System.out.println(securityProperties.getLogoutUrl()); System.out.println(url); } }
静态方法读取
-
public class Test { private static int cookieTimeout; private static void getProperties() { try { Properties properties = new Properties(); InputStream stream = CookiesUtils.class.getClassLoader().getResourceAsStream("application.yml"); properties.load(stream); String property = properties.getProperty("cookie-timeout"); cookieTimeout = Integer.valueOf(property); } catch (IOException e) { } } public static void test() { getProperties(); System.out.println(cookieTimeout); } }
属性中的占位符
-
#tocmat server: session: #获取其它配置信息的值 timeout: ${project.security.session-timeout} #自定义配置 project: security: #一小时 session-timeout: PT1H
-
下一篇: Spring MVC