SpringBoot的自动配置是一个运行时(更准确的说,是应用程序启动时)的过程,考虑了众多因素,才决定Spring配置应该用哪个,不该用哪个。该过程是SpringBoot自动完成的。
起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的***传递依赖***,这些东西加在一起即支持某项功能。简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能。
提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。
注意:SpringBoot并不是对Spring功能上的增强,而是提供了一种快速使用Spring的方式。
导入起步依赖:
<!-- springboot工程需要继承父工程-->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.5.RELEASE</version>
</parent>
<dependencies>
<!-- web开发的起始步骤-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
引导类,项目入口:
/**
* 引导类。SpringBoot项目的入口
*/
@SpringBootApplication
public class HelloApplication {
public static void main(String[] args) {
SpringApplication.run(HelloApplication.class,args);
}
}
小结:
起步依赖原理分析
配置文件分类:
SpringBoot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用application.properties或者application.yml (application.yaml)进行配置。
server.properties=8080
server:
port: 8080
注意:当在同一级目录下,.properties .yml .yaml三个配置文件同时存在的时候,优先级properties>yml>yaml
YAML全称是YAML Ain’t Markup Language。YAML是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持YAML库的不同的编程语言程序导入,比如:C/C+ +,Ruby, Python,Java, Perl,C#, PHP等。YML文件是以数据为核心的,比传统的xml方式更加简洁。YAML文件的扩展名可以使用.yml或者.yaml。
person:
name:zhangsan
# 行内写法
person:{name:zhangsan}
address:
- beijing
- shanghai
# 行内写法
address:[beijing,shanghai]
msg1:'hello \n world' #单引忽略转义字符
msg2:”hello \n wordl“ #双引不忽略转义字符
name: lisi
person:
name:${name} # 引用上边定义的name
读取配置内容
example:
- 1.
@Value("${person.name}")
private String name2;
- 2.
@Autowired
private Environment env;
System.out.println(env.getProperty("person.name"));
- 3.
// 加入依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</dependency>
//Component注解表示 该类会被SpringBoot所识别
@Component
// prefix 表示前缀
// Configuration 表示读取配置信息
@ConfigurationProperties(prefix = "person")
public class Person {
private String name;
private int age;
private String[] address;
我们在开发Spring Boot应用时,通常同一套程序会被安装到不同环境,比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。profile功能就是来进行动态配置切换的。
---
server:
port: 8081
spring:
profiles: dev
---
server:
port: 8082
spring:
profiles: test
---
server:
port: 8083
spring:
profiles: pro
---
spring:
profiles:
active: pro
SpringBoot程序启动时,会从以下位置加载配置文件:
加载顺序为上文的排列顺序,高优先级配置的属性会生效
通过官网查看外部属性加载顺序。
实现步骤:
/**
* UserServiceTest的测试类
*/
@RunWith(SpringRunner.class)
@SpringBootTest(classes = SpringbootTestApplication.class)
public class UserServiceTest {
@Autowired
private UserService userService;
@Test
public void testAdd(){
userService.add();
}
}
实现步骤
注意:如果是.xml的方式整合mybatis,需要在application.yml文件中配置mybatis
example:
# mybatis
mybatis:
mapper-locations: classpath:mapper/*Mapper.xml # mapper的映射文件路径
type-aliases-package: com.itheima.springbootmybatis.domain # 别名
# config-location: # 指定mybatis的核心配置文件啊