pom.xml最基本的配置
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.9.RELEASE</version>
</parent>
是用来管理springboot里面所有的依赖版本
springboot的版本仲裁中心(没有在dependencies里面管理的依赖需要声明版本号)
**启动器**
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
spring-boot-starter:spring-boot场景启动器;springboot将所有的功能场景都抽取出来,做成了一个个的starter,只要在项目中引入所需要的starter,其相关场景所需要的依赖都会被导入进来。需要什么功能就导入什么样的场景启动器
例如spring-boot-starter-web:就是帮我们导入了web功能所正常运行所需要的组件
重要注解
@SpringBootApplication
@SpringBootApplication
来标注一个主程序类,说明这是一个Spring Boot应用,应该运行这个类的main方法来启动SpringBoot应用;
@ConfigurationProperties
@ConfigurationProperties
告诉springboot将带有这个注解的类中的属性与配置文件中的相关配置进行绑定,其中参数prefix = “person”:从配置文件中名为person下面的所有属性进行一一映射。默认从全局配置文件中获取值;
只有这个组件是容器中的组件,才能使用容器提供@ConfigurationProperties
功能,所以还需要子在这个类上添加@Component
注解
注意:对于properties文件会出现乱码问题,需要设置,file——setting—file Encodings
@Value
<property name="lastName" value="字面量/${key}从环境变量、配置文件中获取值/#{SpEL}"></property>
@Value
可以有三种获取值得方式,就像上面value值的写法一样
@Value("${person.last-name}")
private String lastName;
//@Value("#{11*2}")
private Integer age;
//@Value("true")
private Boolean boss;
@ConfigurationProperties | @Value | |
---|---|---|
功能 | 批量注入配置文件中的属性 | 一个个指定 |
松散绑定(松散语法) | 支持 | 不支持 |
SpEL | 不支持 | 支持 |
JSR303数据校验 | 支持 | 不支持 |
复杂类型封装 | 支持 | 不支持 |
配置文件yml还是properties他们都能获取到值;
如果说,我们只是在某个业务逻辑中需要获取一下配置文件中的某项值,使用@Value
;
如果说,我们专门编写了一个javaBean来和配置文件进行映射,我们就直接使用@ConfigurationProperties
;
@Component
@Component
就是告诉spring,把我注册到容器中,spring会自动提取相关信息。于是我们就不用写麻烦的xml配置文件,
注意:当使用Autowired注解时显示bean类型不存在,可能是因为目录结构错误,需要将其放到application启动类的同一个目录或者他的子目录下
或者在指定的application类上加上这么一行注解,手动指定application类要扫描哪些包下的注解@ComponentScan(basePackages = "com.springboot1.bean1")
@PropertySource
@PropertySource
加载指定的配置文件,@PropertySource(value = {"classpath:person.properties"})
,这个注解是添加到需要绑定配置文件的那个类上和@ConfigurationProperties
在同一个类上。
@ImportResource
@ImportResource
导入Spring的配置文件,让配置文件里面的内容生效。
Spring Boot里面没有Spring的配置文件,我们自己编写的配置文件,也不能自动识别;
想让Spring的配置文件生效,加载进来;@ImportResource(locations ={"classpath:bean.xml"} )
标注在一个配置类上
@Configuration
SpringBoot推荐给容器中添加组件的方式;推荐使用全注解的方式
1、配置类加上@Configuration
—–>相当于Spring配置文件
指明当前类是一个配置类;就是来替代之前的Spring配置文件,即相当于之前写的bean.xml
2、使用@Bean
给容器中添加组件,即相当于bean.xml中的<bean></bean>
@Configuration
public class MyAppConfig {
//将方法的返回值添加到容器中;容器中这个组件默认的id就是方法名
@Bean
public HelloService helloService02(){
System.out.println("配置类@Bean给容器中添加组件了...");
return new HelloService();
}
}
配置文件占位符
1、随机数
${random.value}、${random.int}、${random.long}
${random.int(10)}、${random.int[1024,65536]}
2、占位符获取之前配置的值,如果没有可以是用:指定默认值
person.last-name=张三${random.uuid}
person.age=${random.int}
person.birth=2017/12/15
person.boss=false
person.maps.k1=v1
person.maps.k2=14
person.lists=a,b,c
person.dog.name=${person.hello:hello}_dog
person.dog.age=15
profile
1、多profile文件
在主配置文件编写时,文件名可以是application-{profile}.properties,默认使用的是application.properties的配置
2、yml指定多文档块方式
三个横线回车后会生成文档块
3、激活指定profile
1、在配置文件中指定要激活那个配置 spring.profiles.active=dev
2、命令行:
打包后执行时
java -jar spring-boot-02-config-0.0.1-SNAPSHOT.jar --spring.profiles.active=dev;
可以直接在测试的时候,配置传入命令行参数
3、虚拟机参数;
-Dspring.profiles.active=dev
6、配置文件加载位置
springboot 启动会扫描以下位置的application.properties或者application.yml文件作为Spring boot的默认配置文件
–file:./config/
–file:./
–classpath:/config/
–classpath:/
优先级由高到底,高优先级的配置会覆盖低优先级的配置;
SpringBoot会从这四个位置全部加载主配置文件;互补配置;
==我们还可以通过spring.config.location来改变默认的配置文件位置==
项目打包好以后,我们可以使用命令行参数的形式,启动项目的时候来指定配置文件的新位置;指定配置文件和默认加载的这些配置文件共同起作用形成互补配置;
java -jar spring-boot-02-config-02-0.0.1-SNAPSHOT.jar –spring.config.location=G:/application.properties
互补配置,例子:当我们的项目打包好以后,发现有些配置文件需要更改,此时不需要重新更改整个项目,然后重新打包再发布,只需要使用命令行来指定一些配置文件即可,新加的根据优先级进行覆盖之前需要更改的内容。
7、外部配置加载顺序
==SpringBoot也可以从以下位置加载配置; 优先级从高到低;高优先级的配置覆盖低优先级的配置,所有的配置会形成互补配置==
yml
基本语法
k:(空格)v:表示一对键值对(空格必须有);
以空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的
字符串默认不用加上单引号或者双引号;
"":双引号;不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思
'':单引号;会转义特殊字符,特殊字符最终只是一个普通的字符串数据