Springboot入门学习第一天

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:表示一对键值对(空格必须有);

空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的
字符串默认不用加上单引号或者双引号;

"":双引号;不会转义字符串里面的特殊字符;特殊字符会作为本身想表示的意思
'':单引号;会转义特殊字符,特殊字符最终只是一个普通的字符串数据

猜你喜欢

转载自blog.csdn.net/ilikejj0/article/details/81187076