【Spring框架家族】SpringBoot基本介绍

SpringBoot概述

SpringBoot提供了一种快速使用Spring的方式,基于约定优于配置的思想,可以让开发人员不必在配置与逻辑业务之间进行思维的切换,全身心的投入到逻辑业务的代码编写中,从而大大提高了开发的效率,在一定程度上缩短了项目周期

Spring缺点

  • 配置繁琐

    • 虽然Spring的组件代码时轻量级的,但是它的配置却是重量级的,一开始,Spring用Xml配置,而且是很多Xml配置
    • Spring2.5引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件显示Xml配置
    • Spring3.0引入了基于java的配置,这是一种类型安全的可重构配置方式,可以代替xml
    • 所有这些配置都代表开发时的损耗,因为在思考Spring特性配置和解决业务问题之间需要进行思维切换,所以编写配置挤占了编写应用程序逻辑的时间,和所有框架一样,Spring实用,但是要求回报也不少
  • 依赖繁琐

    • 项目的依赖管理也是一件耗时耗力的事情,在环境搭建时,需要分析要导入哪些库的坐标,而且还需要分析导入与之有依赖关系的其他库的坐标,一旦选错依赖的版本,随之而来的不兼容问题就会严重阻碍项目的开发进度

SpringBoot功能

  • 自动配置
    Spring Boot的自动配置是一个运行时(更准确地说,是应用程序启动时)的过程,考虑了众多因素,才决定Spring配置应该用哪个,不该用哪个。该过程是SpringBoot自动完成的。

  • 起步依赖
    起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的传递依赖,这些东西加在一起即支持某项功能。
    简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能。

  • 辅助功能
    提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。

  • 注意:Spring Boot 并不是对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式。

SpringBoot快速搭建项目

导入SpringBoot起步依赖

    	<!--springboot工程必须要继承的父工程-->
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.1.8.RELEASE</version>
        </parent>
    
        <dependencies>
            <!--web开发的起步依赖-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
        </dependencies>

定义Controller

    @RestController
    public class HelloController {
    
        @RequestMapping("/hello")
        public String hello(){
            return " hello Spring Boot !";
        }
    }

编写引导类

    /**
     * 引导类。 SpringBoot项目的入口,此类需和Controller在同一个包下
     */
    // 告诉框架这是SpringBoot应用
    @SpringBootApplication
    public class HelloApplication {
    
        public static void main(String[] args) {
            // SpringApplication一个Spring应用,run启动命令
            SpringApplication.run(HelloApplication.class,args);
        }
    }

SpringBoot起步依赖原理分析
  • 在spring-boot-starter-parent中定义了各种技术的版本信息,组合了一套最优搭配的技术版本。
  • 在各种starter中,定义了完成该功能需要的坐标合集,其中大部分版本信息来自于父工程。
  • 我们的工程继承parent,引入starter后,通过依赖传递,就可以简单方便获得需要的jar包,并且不会存在版本冲突等问题。
SpringBoot配置-配置文件分类
SpringBoot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用application.properties或者application.yml(application.yaml)进行配置。

1. 默认配置文件名称:application
2. 在同一级目录下优先级为:properties>yml > yaml

例如:配置内置Tomcat的端口

* properties:
	server.port=8080

* yml:
server: 
	port: 8080 -- 冒号后面必须加空格
SpringBoot配置-yaml基本语法
YAML全称是YAML Ain't Markup Language.YAML是一种直观的能够被电脑识别的数据序列化格式,并且容易被人类阅读,容易和脚本语言交互,可以被支持YAML库的不同编程语言程序导入
比如:C/C++,Ruby,Python,java,perl,C#,PHP等,YML文件时以数据为核心的,比传统的XML更加简洁
YAML文件扩展名可以使用.yml或者.yaml
  • 大小写敏感
  • 数据值前边必须有空格,作为分隔符
  • 使用缩进表示层级关系
  • 缩进时不允许使用Tab键,只允许使用空格(各个系统 Tab对应的 空格数目可能不同,导致层次混乱)。
  • 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  • ‘’#" 表示注释,从这个字符一直到行尾,都会被解析器忽略。

对比:

# properties:
server.port=8080
server.address=127.0.0.1

# xml
<server> 
  <port>8080</port> 
  <address>127.0.0.1</address>
</server>
# yml
server: 
  port: 8080  
  address: 127.0.0.1
name: abc

SpringBoot配置-yaml数据格式

对象(map):键值对的集合。

    person:  
       name: zhangsan
    # 行内写法,冒号后面都要有空格
    person: {name: zhangsan}

数组:一组按次序排列的值

    address:
    # 使用 “- ”表示数组每个元素
      - beijing
      - shanghai
    # 行内写法
    address: [beijing,shanghai]

纯量:单个的、不可再分的值

    msg1: 'hello \n world'  # 单引忽略转义字符
    msg2: "hello \n world"  # 双引识别转义字符

参数引用

    name: 赵丽颖
    person:
      name: ${name} # 引用上边定义的name值

SpringBoot配置-获取数据

@Value

       #获取普通配置
       @Value("${name}") // ${写的是配置文件中的key}
       private String name;
       #获取对象属性
       @Value("${person.name}")
       private String name2;
       #获取数组
       @Value("${address[0]}")
       private String address1;
       #获取纯量
       @Value("${msg1}")
       private String msg1;

Evironment

     @Autowired
     private Environment env;
    
     System.out.println(env.getProperty("person.name"));
     System.out.println(env.getProperty("address[0]"));

两种区别:

  • @Value是直接通过key获取值,在多个方法都可以使用
  • Evironment对象通过调用getProperty(“key”)也可以获取值,但是如果在多个方法中调用,则需要多次调用getProperty(“key”)

@ConfigurationProperties 作用:可以将javaBean与配置文件中的内容进行绑定

注意:prefix一定要写

 @Component
    @ConfigurationProperties(prefix = "person")
    public class Person {
    
        private String name;
        private int age;
        private String[] address;

补充:
实体类属性标记@Validated,自动校验
属性报价NotNull非空

SpringBoot配置-profile

在开发Spring Boot应用时,通常同一套程序会被安装到不同环境,比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。profile功能就是来进行动态配置切换的。

  • profile是用来完成不同环境下,配置动态切换功能的。
  • profile配置方式:
    • 多profile文件方式:提供多个配置文件,每个代表一种环境。有一个主配置文件
      application-dev.properties/yml 开发环境
      application-test.properties/yml 测试环境
      application-pro.properties/yml 生产环境
    • yml多文档方式
      在yml中使用 - - - 分隔不同配置,两个 - - - 之就是一个独立文档
      使用spring.profiles属性为文档取名
  • profile激活方式
    配置文件: 再配置文件中配置:spring.profiles.active=dev
    虚拟机参数:在VM options 指定:-Dspring.profiles.active=dev
    命令行参数:java –jar xxx.jar --spring.profiles.active=dev

SpringBoot配置-项目内部配置文件加载顺序

加载顺序为上文的排列顺序,高优先级配置的属性会生效

  • file:./config/:当前项目下的/config目录下
  • file:./ :当前项目的根目录
  • classpath:/config/:classpath的/config目录
  • classpath:/ :classpath的根目录

SpringBoot配置-项目外部配置加载顺序

外部配置文件的使用是为了对内部文件的配合

1.命令行

java -jar app.jar --name="Spring“ --server.port=9000

2.指定配置文件位置

 java -jar myproject.jar --spring.config.location=e://application.properties

3.外部不带profile的properties文件

    classpath:/config/application.properties
    classpath:/application.properties
发布了34 篇原创文章 · 获赞 14 · 访问量 1568

猜你喜欢

转载自blog.csdn.net/Wan_Yuan/article/details/104818144
今日推荐