spring boot 2

一、SpringBoot 配置文件格式

SpringBoot 支持两种主流配置文件格式,核心功能一致,仅语法不同:

1. application.properties(键值对格式)

  • 语法:key=value,层级通过.分隔

properties

复制代码
server.port=9090
server.servlet.context-path=/start

2. application.yml/application.yaml(YAML 格式)

  • 语法:层级缩进(2 个空格)+ 冒号 + 空格,结构更清晰

yaml

复制代码
server:
  port: 9191
  servlet:
    context-path: /start2

关键规则

  • YAML 中冒号后必须跟一个空格作为分隔符
  • 层级关系通过空格缩进表示,相同层级左侧对齐
  • 支持字符串、布尔值、数字等多种数据类型

二、YML 配置信息的书写与获取

1. 配置书写示例

示例 1:三方服务配置(阿里云 OSS)

yaml

复制代码
ali-yun:
  oss:
    endpoint: https://oss-cn-hangzhou.aliyuncs.com
    access-key-id: LTAI5tQ8e13SYZUMTjMEEQV
    access-key-secret: MffMJoM24sc59SDEEJQDb0cfBVOAC9
    bucket-name: gsw
示例 2:自定义配置(QQ 邮箱)

yaml

复制代码
email:
  user: 593140521@qq.com
  code: jfejwezhcrzcbbbb
  host: smtp.qq.com
  auth: true

2. 配置信息的两种获取方式

方式 1:@Value 注解(单个配置项获取)

适用于少量配置项,语法:@Value("${配置键名}")

java

运行

复制代码
@RestController
public class EmailController {
    @Value("${email.user}")
    private String emailUser;

    @Value("${email.code}")
    private String emailCode;

    // 使用配置项
}
方式 2:@ConfigurationProperties 注解(批量绑定)

适用于一组相关配置,通过前缀批量绑定到实体类

java

运行

复制代码
@Component
@ConfigurationProperties(prefix = "email")
public class EmailProperties {
    // 成员变量名必须与配置文件中的键名一致
    private String user;
    private String code;
    private String host;
    private boolean auth;

    // getter/setter 方法(必须)
    public String getUser() { return user; }
    public void setUser(String user) { this.user = user; }
    // 其他getter/setter省略
}

优势:批量绑定更简洁,支持配置校验、IDE 提示,适合复杂配置场景。


三、SpringBoot 整合 MyBatis

1. 核心依赖引入

pom.xml 中引入 MyBatis 官方提供的 SpringBoot 起步依赖:

xml

复制代码
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>3.0.0</version>
</dependency>

2. 自动配置原理

引入依赖后,SpringBoot 会自动配置以下核心组件,无需手动编写 XML:

  • SqlSessionFactoryBean:MyBatis 核心工厂类
  • MapperScannerConfigurer:Mapper 接口扫描器,自动注册 Mapper
  • DataSource:数据源配置,可通过 application.yml 配置数据库连接

3. 数据库配置示例(application.yml)

yaml

复制代码
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC
    username: root
    password: 123456

# MyBatis配置
mybatis:
  mapper-locations: classpath:mapper/*.xml  # Mapper XML文件路径
  type-aliases-package: com.example.entity  # 实体类别名包
相关推荐
SelectDB1 小时前
从 Machine-Readable 到 Agent-Ready:面向智能体的数据库接口演进
大数据·数据库·agent
画江湖Test1 小时前
Redis 块的原理
数据库·redis·缓存·性能优化
流烟默1 小时前
国产数据库CERDB是什么以及服务启停
数据库·cerdb
数据库小学妹1 小时前
关系型数据库核心原理拆解:SQL解析、事务引擎、存储结构全链路分析
数据库·经验分享·sql·数据库架构·dba
海市公约1 小时前
Redis主从复制全量同步七步时序与命令传播机制详解
数据库·redis·缓存·主从复制·高可用架构·全量同步
我是唐青枫1 小时前
Java JdbcTemplate 实战指南:用 Spring 轻量完成数据库增删改查
java·数据库·spring
梓䈑2 小时前
【MySQL】MySQL安装 和 配置
数据库·mysql
小马爱打代码2 小时前
Redis 和 MySQL 双写一致性:延迟双删、读写锁、MQ、Canal 怎么选?
数据库·redis·mysql
数智顾问2 小时前
(133页PPT)数据中心基础设施规划设计(附下载方式)
大数据·数据库·人工智能