您的位置: 首页 > 编程笔记

SpringBoot入门及YML文件详解

Spring Boot YML 时间:2019-08-09  查看:6   收藏

SpringBoot

简介

微框架,与 Spring4 一起诞生,基于约定、生来为了简化 spring 的配置

优点

  • 可以快速的上手,整合了一些子项目(开源框架或者第三方开源库)

  • 可以依赖很少的配置快速的搭建项目

  • 基于 spring 使开发者快速入门,门槛很低。

  • 可以创建独立运行的应用而不需要依赖容器

  • 提供很多 maven 极简配置,缺点是会引入很多不需要的包

  • 提供可视化的相关功能,方便监控

  • 简化配置

使用场景

  • 有 Spring 的地方都行

  • J2EE/web 项目

  • 微服务的基础

需要的Java版本:1.8+

核心功能

起步依赖

起步依赖实际上就是一个 Maven 项目对象模型,定义了对其他库的传递依赖。这些东西加在一起支持某项功能。从一定程度上规避了依赖冲突问题

自动配置

对于一些约定的属性,springboot 在 spring-boot-autoconfigure 包下 META-INF/spring-configuration-metadata.json 文件中进行了默认属性配置。如果我们不通过配置文件覆盖这个配置,在应用程序启动时,如果应用程序启动条件符合注解的要求,就会采用这些默认配置来完成应用的初始化配置。如果我们覆盖这个配置,就会采用我们定义的配置

原理分析:

@SpringBootConfiguration // 相当于 @Configuration
@EnableAutoConfiguration // 开启自动配置
@ComponentScan( // 配置注解扫描。扫描该包及其子包的注解
    excludeFilters = {@Filter(
    type = FilterType.CUSTOM,
    classes = {TypeExcludeFilter.class}
), @Filter(
    type = FilterType.CUSTOM,
    classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {}

快速搭建

使用IDEA可以快速的创建 springboot 项目,当然也可以通过创建 Maven 工程并导入依赖来新建 springboot 项目

快速创建的工程只能选择最新的几个版本,如果想使用老版本可以在工程搭建完成后手动更改版本号

快速创建springboot工程

配置文件

SpringBoot使用一个全局的配置文件,并且名称是固定的,配置文件有两种(截图自来自spring-boot-starter-parent-1.5.9.RELEASE.pom):

1565140556810

由该 pom 文件也可以得出一个结论,当同时存在 .yml 和 .properties 配置文件且配置了相同的参数时,会因为后加载 properties 而导致 yml 里面的相同配置配覆盖。当然实际开发也几乎不会有人这么做

application.properties 就是常规的 key=value 格式配置文件,当要配置的参数比较多就会发现他的层次不是那么清晰,不便于阅读

application.yml

yml(也叫yaml):是一种以数据为中心的配置文件, 比 json,xml 等更适合做配置文件

yml基本语法:

key:(空格)value ---> 键和值中间用冒号空格!!!连接,记住是冒号空格,缺一不可

不同层级的关系用空格表示,只要是左对齐的一列数据,都是同一层级的:

server:
 port: 8888
字符串

默认不用加引号,

如果加上 “” 双引号,双引号内的特殊字符将作为本身的意思展示

如果加上 ‘’ 单引号,单引号内的特殊字符将会被转义

对象、Map

在下一行来写对象的属性和值的关系;注意缩进

user:
  name: yaya
  age: 18
  address: xian
firends: {name: zhangsan, age: 18}
# map里面的 冒号后面也得有 空格
数组 List、Set

用 - 值表示数组中的一个元素

arr:
  - 1
  - 2
  - 3
例:用yml构造一个对象
person: # 前缀名
  name: yaya
  age: 18
  address: 西安
  arr:
    - 1
    - 2
    - 3
  friend: {name: zs,age: 13}
  son:
    name: 张三
    age: 13
@Component // 配置 Bean 被 Spring 容器管理
@ConfigurationProperties(prefix = "person") // 配置文件和实体进行映射,配置前缀,这里对应 yml 文件中的对象名
public class User {
    private String name;
    private int age;
    private String address;
    private List<Integer> arr;
    private Map<String, Object> friend;
    private Son son; // 引入一个外部类
    setter/getter ...   
}
public class Son{ // 该类不用加任何注解,框架还是会将 yml 中的属性映射到该类的属性上
    private String name;
    private int age;
}

@Value 获取值和 @ConfigurationProperties 获取值的比较:


@ConfigurationProperties @Value
功能 批量注入配置文件中的属性 一个个指定
松散绑定(松散语法) 支持 不支持
SpEL 不支持 支持
JSR303数据校验 支持 不支持
复杂类型封装 支持 不支持

Bean对Json映射处理

@JsonIngore

@JsonFormat

public class Person {
    private String name;
    @JsonIgnore // 转换时忽略该字段
    private Integer age;
    // Json格式化
    @JsonFormat(pattern = "yyyy年MM月dd日 HH:mm:ss", locale = "zh", timezone = "GMT+8")
    private Date birthday;
}
@RequestMapping("/person")
public Person person(){
    Person p = new Person();
    p.setName("张三");
    p.setAge(23);
    p.setBirthday(new Date());

    System.out.println(p);
    return p;
}

这时,返回的JSON数据中就不会出现 age 属性,并且对 birthday 进行了格式化

{"name":"张三","birthday":"2019年08月07日 15:34:45"}

@JsonInclude

忽略null属性

如果前端需要将 null 返回为空串/不返回,我们可以使用。

@JsonInclude(content = JsonInclude.Include.NON_NULL) // 如果该属性为 null,则它不参与序列化

注意:在 spring-boot 1.5.9 版本中, @JsonInclude 注解没有对 value 和 content 关联(没有在 content 上配置 @AliasFor 注解),所以刚刚上面的配置是无效的。采用下面的配置:

@JsonInclude(JsonInclude.Include.NON_NULL)

也可以在 yml 文件中配置全局忽略,配置方法如下:

spring:
  jackson:
    default-property-inclusion: non_null

Devtools热部署

  1. 在pom.xml中添加

<dependency>  
    <groupId>org.springframework.boot</groupId>  
    <artifactId>spring-boot-devtools</artifactId> 
    <!-- 关闭此项的依赖传递,即别的项目依赖该项目时,不会传递依赖此jar -->
    <optional>true</optional>
</dependency>
  1. 配置IDEA自动编译
    1563626078528

  2. 按 Ctrl+Shift+Alt+/ , 打开 Registry .配置IDEA运行时自动编译

1563626150561

一些额外的配置

spring:
  freemarker:
    cache: true # 关闭thymeleaf的页面缓存
  devtools:
    remote:
      restart:
        enabled: false # 热部署开关
    restart:
      additional-paths: springboot-demo/src/main/java # 设置重启的目录,对那个目录的文件进行修改后需要重启
      exclude: static/** # 设置classpath下 static 目录内容修改后不重启。一般设置为静态资源目录

资源文件属性配置

配置资源文件属性读取

有时我们采用一些自己定义的资源文件(非 application.xxx )想要获取里面的属性值时,需要采用以下配置

<!-- 配置文件处理器依赖,配置后可以进行资源配置文件的加载 -->
<!-- 配置这个依赖后,书写yml文件时自定义的属性会有提示 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-configuration-processor</artifactId>
    <optional>true</optional>
</dependency>
@Configuration // 也是一个 @Component 语义化注解
@ConfigurationProperties(value = "admin") // 配置文件中共有的前缀名
@PropertySource(value = "classpath:user.properties") // 资源文件的位置
public class Admin implements Serializable {
    private String username;
    private String password;
}

配置tomcat

server:
  port: 8888 # 端口号
  session-timeout: 60 # session 超时时间/分钟,默认是30
  context-path: /demo # 全局虚拟路径
  error:
    path: /error.html # 错误跳转页
  tomcat:
    uri-encoding: utf-8 # 设置tomcat编码

整合模板引擎

整合FreeMarker

导入FreeMarker启动器

 <!-- freemarker -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>

配置 freemarker

spring:
  freemarker:
    cache: false # 关闭freemarker缓存。即时刷新。上线环境建议修改为 true
    template-loader-path: classpath:/template # 模板文件的路径
    charset: UTF-8 # 编码,默认也是u8
    check-template-location: true # 检查模板路径
    content-type: text/html # 默认也是 text/html

整合 mybatis

添加 mybatis 起步依赖,mysql 数据库依赖

<!-- mybatis起步依赖 -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
</dependency>
<!-- mysql数据库依赖 -->
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <scope>runtime</scope>
</dependency>

在 yml 文件中配置数据源

spring:
  datasource:
    username: keats
    password: 521
    url: jdbc:mysql://localhost:3306/springboot?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=UTC
    driver-class-name: com.mysql.jdbc.Driver
    # 对于mysql数据库连接版本 v6+ 这个驱动要修改成 com.mysql.cj.jdbc.Driver。当然也可以什么都不写用默认的

MyBatis相关配置

mybatis:
  mapper-locations: classpath:mapping/*Mapping.xml # 配置 mapper 文件所在的路径
  type-aliases-package: cn.keats.mybatisdemo.pojo # 配置这个包下的所有类起别名

创建实体类

public class User implements Serializable {
    private Integer id;
    private String username;
    private String password;
    private Date birthday;
    setter/getter ...
}

创建映射关系接口

接口要添加 @Mapper 注解,这样容器中才会有接口的实现类

@Mapper // 
public interface UserMapper {

    @Select("select * from user where id = #{id}")
    User selectById(Integer id);  // 采用注解的方式书写SQL语句

    void insert(User user); // 采用mapper配置文件的方式书写SQL语句
}

Mapper映射文件,四个要求

namespace 等于 UserMapper 接口的全限定名

id 等于 方法名

parameterType 等于方法的参数类型

resaultType 等于方法的返回值类型

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//ibatis.apache.org//DTD Mapper 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">

<mapper namespace="cn.keats.mybatisdemo.mapper.UserMapper">

    <insert id="insert" parameterType="user">
        insert into user values (null , #{username}, #{password}, #{birthday})
    </insert>

</mapper>

整合 Redis

导入Redis启动器

 <!-- redis -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置host和端口

其实从图中可以看出,springboot默认对Redis的配置就是 localhost:6379 所以如果Redis也是这个路径,可以不用自行配置

1565250443051

 

0% (0)
0% (0)
0.118319s