Spring Boot是快速搭建Spring工程的脚手架,简化配置与依赖关系(约定大于配置),让我们把精力集中在业务部分
创建一个Hello World的Web工程
直接Next -> 填写工程坐标 -> 创建
父工程管理jar包,没有业务代码,子工程需要jar包时不用写版本号
<!-- 父工程 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
</parent>
<!-- 设置JDK版本 -->
<properties>
<java.version>1.8</java.version>
</properties>
<!-- 添加依赖 -->
<dependencies>
<!-- 场景启动器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
注意Application要放在根目录下,因为会去Application的同级目录去扫描,注意左边有层级结构
@SpringBootApplication
public class Application {
public static void main(String[] args) {
//SpringBoot启动
SpringApplication.run(Application.class,args);
}
}
@RestController
public class HelloController {
//请求映射
@RequestMapping(value = "hello",method = RequestMethod.GET)
public String hello(){
return "Hello Worlddddd";
}
}
启动SpringBoot应用
打开浏览器测试成功
总结
我们来看看@SpringBootApplication这个组合注释,底层还包括两个注解
总结:SpringBoot启动时从类路径下META_INF/spring.factories获取EnableAutoConfiguration指定的值,将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作
jdbc:
driverclassName: com.mysql.jdbc.Driver
url: jdbc:mysql://localhost:3306/test?serverTimezone=UTC
username: root
password: howl
<!-- 注解解析器 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
/*
* @ConfigurationProperties把配置文件的属性注入该类中
*/
@Component
@ConfigurationProperties(prefix = "jdbc")
public class JDBC {
private String driverclassName;
private String url;
private String username;
private String password;
//各种Getters和Setters
}
常用注解
//将配置文件的属性注入到该对象中,只有这个注解是生效的,需要配合@EnableConfigurationProperties注解,或加入@Component注解
@ConfigurationProperties(prefix = "jdbc")
//属性注入
@value("${name}")
//使对应的配置文件生效加入到Bean容器
@EnableConfigurationProperties(JDBCProperties.class)
//声明一个类为配置类,代替xml文件,一般配合@Bean注解
@Configuration
//声明在方法上,将返回值加入Bean容器,代替<bean>标签
@Bean
//------------推荐使用上面来指定配置文件,在主目录下创一个config包-------------
//指定外部属性文件,这时还没生效,需要配合下面的注解
@PropertySource(value = {"classpath:other.properties"})
//加载多个配置文件,放在主程序类上
@ImportResourcec(locations = {"classpath:other.yml"})
@ConfigurationProperties和@value区别
@ConfigurationProperties | @value | |
---|---|---|
功能 | 批量注入配置 | 单个指定 |
松散绑定 | 支持 | 不支持 |
SpEL | 不支持 | 支持 |
JSR303数据校验 | 支持 | 不支持 |
复杂数据类型 | 支持 | 不支持 |
我们在resources下建立两个配置文件
二者用上面的JDBC配置文件,不同于username,一个为root,一个为Howl
激活测试
# 在application.yml主配置文件中添加下面配置
spring:
profiles:
active: dev
Controller代码
//请求映射
@RequestMapping(value = "hello",method = RequestMethod.GET)
public String hello(){
return jdbc.getUsername();
}
未激活dev前,username为root
激活dev后为,username为Howl