0


【Spring Boot实战教程】第一章——多环境配置与第三方技术整合

前言

在现代软件开发中,应用程序往往需要在不同的环境中运行,比如开发环境、测试环境和生产环境。每个环境可能有不同的配置需求,如数据库连接、服务器端口、安全设置等。手动管理和切换这些配置不仅耗时,而且容易出错。Spring Boot通过其强大的多环境配置支持,极大地简化了这一过程,使得开发者可以更加专注于业务逻辑的实现,而不是繁琐的配置管理。

Spring Boot的设计理念之一就是“约定优于配置”,它通过一系列的默认配置和自动配置机制,减少了开发者的配置工作量。特别是在多环境配置方面,Spring Boot提供了一套简单而强大的机制,使得开发者可以轻松地管理和切换不同环境下的配置。

一、SpringBoot简介

1. 入门案例

  • SpringBoot是由Pivotal团队提供的全新框架,其设计目的是用来简化Spring应用的初始搭建以及开发过程

  • 原生开发SpringMVC程序过程

1.1 入门案例开发步骤

手动创建方式:

①:新建maven项目

②:引入依赖

③:创建引导类

③:开发控制器类

  1. @RestController
  2. @RequestMapping("/books")
  3. public class BookController {
  4. @GetMapping("/{id}")
  5. public String getById(@PathVariable Integer id) {
  6. System.out.println("id ==> " + id);
  7. return "hello , spring boot! ";
  8. }
  9. }

④:运行自动生成的Application类

SpringBoot脚手架方式

①:创建新模块,选择Spring初始化,并配置模块相关基础信息

②:选择当前模块需要使用的技术集

③:开发控制器类

  1. @RestController
  2. @RequestMapping("/books")
  3. public class BookController {
  4. @GetMapping("/{id}")
  5. public String getById(@PathVariable Integer id) {
  6. System.out.println("id ==> " + id);
  7. return "hello , spring boot! ";
  8. }
  9. }

④:运行自动生成的Application类

  • 最简SpringBoot程序所包含的基础文件
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <parent>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-parent</artifactId>
  8. <version>2.5.0</version>
  9. </parent>
  10. <groupId>com.itheima</groupId>
  11. <artifactId>springboot-01-quickstart</artifactId>
  12. <version>0.0.1-SNAPSHOT</version>
  13. <dependencies>
  14. <dependency>
  15. <groupId>org.springframework.boot</groupId>
  16. <artifactId>spring-boot-starter-web</artifactId>
  17. </dependency>
  18. </dependencies>
  19. </project>
  1. @SpringBootApplication
  2. public class Application {
  3. public static void main(String[] args) {
  4. SpringApplication.run(Application.class, args);
  5. }
  6. }
  • Spring程序与SpringBoot程序对比

注意事项:

基于idea开发SpringBoot程序需要确保联网且能够加载到程序框架结构

1.2 基于SpringBoot官网创建项目

1.3 SpringBoot项目快速启动

① 对SpringBoot项目打包(执行Maven构建指令package)

② 执行启动指令

  1. java -jar springboot_01_quickstart.jar # 项目的名称根据实际情况修改

注意事项:

jar支持命令行启动需要依赖maven插件支持,请确认打包时是否具有SpringBoot对应的maven插件。

  1. <build>
  2. <plugins>
  3. <plugin>
  4. <groupId>org.springframework.boot</groupId>
  5. <artifactId>spring-boot-maven-plugin</artifactId>
  6. </plugin>
  7. </plugins>
  8. </build>

2. SpringBoot概述

问题导入
  • 入门案例中没有引入spring-webmvc等依赖包,没有配置Tomcat服务器,为什么能正常启动?

  • 我们没有配置端口号,为什么端口是8080?

2.1 起步依赖
  • starter

    • SpringBoot中常见项目名称,定义了当前项目使用的所有项目坐标,以达到减少依赖配置的目的
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <modelVersion>4.0.0</modelVersion>
  5. <parent>
  6. <groupId>org.springframework.boot</groupId>
  7. <artifactId>spring-boot-starter-parent</artifactId>
  8. <version>2.5.0</version>
  9. </parent>
  10. <groupId>com.itheima</groupId>
  11. <artifactId>springboot-01-quickstart</artifactId>
  12. <version>0.0.1-SNAPSHOT</version>
  13. <dependencies>
  14. <dependency>
  15. <groupId>org.springframework.boot</groupId>
  16. <artifactId>spring-boot-starter-web</artifactId>
  17. </dependency>
  18. </dependencies>
  19. </project>
  1. <project xmlns="http://maven.apache.org/POM/4.0.0"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  4. <modelVersion>4.0.0</modelVersion>
  5. <groupId>org.springframework.boot</groupId>
  6. <artifactId>spring-boot-dependencies</artifactId>
  7. <version>2.5.0</version>
  8. <packaging>pom</packaging>
  9. <properties>
  10. <servlet-api.version>4.0.1</servlet-api.version>
  11. ...
  12. </properties>
  13. </project>
  • parent - 所有SpringBoot项目要继承的项目,定义了若干个坐标版本号(依赖管理,而非依赖),以达到减少依赖冲突的目的- spring-boot-starter-parent(2.5.0)与 spring-boot-starter-parent(2.4.6)共计57处坐标版本不同
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
  4. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  5. <modelVersion>4.0.0</modelVersion>
  6. <parent>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-dependencies</artifactId>
  9. <version>2.5.0</version>
  10. </parent>
  11. <artifactId>spring-boot-starter-parent</artifactId>
  12. <packaging>pom</packaging>
  13. ...
  14. </project>
  • 实际开发 - 使用任意坐标时,仅书写GAV中的G和A,V由SpringBoot提供- 如发生坐标错误,再指定version(要小心版本冲突)
  1. <dependency>
  2. <groupId>junit</groupId>
  3. <artifactId>junit</artifactId>
  4. <version>${junit.version}</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>javax.servlet</groupId>
  8. <artifactId>javax.servlet-api</artifactId>
  9. <version>${servlet-api.version}</version>
  10. </dependency>
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
  4. <parent>
  5. <groupId>org.springframework.boot</groupId>
  6. <artifactId>spring-boot-starter-parent</artifactId>
  7. <version>2.5.0</version>
  8. </parent>
  9. <dependencies>
  10. <dependency>
  11. <groupId>org.springframework.boot</groupId>
  12. <artifactId>spring-boot-starter-web</artifactId>
  13. </dependency>
  14. <dependency>
  15. <groupId>org.springframework.boot</groupId>
  16. <artifactId>spring-boot-starter-test</artifactId>
  17. <scope>test</scope>
  18. </dependency>
  19. </dependencies>
  20. </project>
2.2 默认配置

tomcat默认配置了端口号为8080

二、基础配置

1. 配置文件格式

问题导入

框架常见的配置文件有哪几种形式?

1.1 修改服务器端口

http://localhost:8080/books/1 >>> http://localhost/books/1

SpringBoot提供了多种属性配置方式

  • application.properties
  1. server.port=80
  • application.yml
  1. server:
  2. port: 81
  • application.yaml
  1. server:
  2. port: 82
1.2 自动提示功能消失解决方案

操作步骤:

1.3 SpringBoot配置文件加载顺序(了解)
  • application.properties > application.yml > application.yaml

注意事项:

  1. SpringBoot核心配置文件名为application

  2. SpringBoot内置属性过多,且所有属性集中在一起修改,在使用时,通过提示键+关键字修改属性

2. yaml

问题导入

什么是yaml,和properties有什么区别?

  • YAML(YAML Ain't Markup Language),一种数据序列化格式

  • 优点: - 容易阅读- 容易与脚本语言交互- 以数据为核心,重数据轻格式

  • YAML文件扩展名 - .yml(主流)- .yaml

2.1 yaml语法规则
  • 大小写敏感

  • 属性层级关系使用多行描述,每行结尾使用冒号结束

  • 使用缩进表示层级关系,同层级左侧对齐,只允许使用空格(不允许使用Tab键)

  • 属性值前面添加空格(属性名与属性值之间使用冒号+空格作为分隔)

  • #表示注释

  • 核心规则:数据前面要加空格与冒号隔开

2.2 yaml数组数据
  • 数组数据在数据书写位置的下方使用减号作为数据开始符号,每行书写一个数据,减号与数据间空格分隔

2.3 yaml数据读取
  • 使用@Value读取单个数据,属性名引用方式:${一级属性名.二级属性名……}

  • 封装全部数据到Environment对象

  • 自定义对象封装指定数据【常用】
  1. public class Enterprise {
  2. private String name;
  3. private Integer age;
  4. private String tel;
  5. private String[] subject;
  6. //自行添加getter、setter、toString()等方法
  7. }

  • 自定义对象封装数据警告解决方案

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-configuration-processor</artifactId>
  4. <optional>true</optional>
  5. </dependency>

3. 多环境开发配置

问题导入

在实际开发中,项目的开发环境、测试环境、生产环境的配置信息是否会一致?如何快速切换?

3.1 多环境启动配置
  • yaml文件多环境启动

  • properties文件多环境启动
  1. #主启动配置文件 application.properties
  2. spring.profiles.active=pro
  1. #环境分类配置文件 application-pro.properties
  2. server.port=80
  1. #环境分类配置文件 application-dev.properties
  2. server.port=81
  1. #环境分类配置文件application-test.properties
  2. server.port=82
3.2 多环境启动命令格式
  • 带参数启动SpringBoot
  1. java jar springboot.jar --spring.profiles.active=test
  2. java jar springboot.jar --server.port=88
  3. java jar springboot.jar --server.port=88 --spring.profiles.active=test

3.3 多环境开发控制

Maven与SpringBoot多环境兼容(步骤)

①:Maven中设置多环境属性

  1. <profiles>
  2. <profile>
  3. <id>dev_env</id>
  4. <properties>
  5. <profile.active>dev</profile.active>
  6. </properties>
  7. <activation>
  8. <activeByDefault>true</activeByDefault>
  9. </activation>
  10. </profile>
  11. <profile>
  12. <id>pro_env</id>
  13. <properties>
  14. <profile.active>pro</profile.active>
  15. </properties>
  16. </profile>
  17. <profile>
  18. <id>test_env</id>
  19. <properties>
  20. <profile.active>test</profile.active>
  21. </properties>
  22. </profile>
  23. </profiles>

②:SpringBoot中引用Maven属性

③:执行Maven打包指令

  • Maven指令执行完毕后,生成了对应的包,其中类参与编译,但是配置文件并没有编译,而是复制到包中

  • 解决思路:对于源码中非java类的操作要求加载Maven对应的属性,解析${}占位符

④:对资源文件开启对默认占位符的解析

  1. <build>
  2. <plugins>
  3. <plugin>
  4. <artifactId>maven-resources-plugin</artifactId>
  5. <configuration>
  6. <encoding>utf-8</encoding>
  7. <useDefaultDelimiters>true</useDefaultDelimiters>
  8. </configuration>
  9. </plugin>
  10. </plugins>
  11. </build>
  • Maven打包加载到属性,打包顺利通过

4. 配置文件分类

问题导入

SpringBoot的配置文件可以放在项目的哪些地方?

  1. java jar springboot.jar --spring.profiles.active=test --server.port=85 --server.servlet.context-path=/heima --server.tomcat.connection-timeout=-1 ... ...
  • SpringBoot中4级配置文件

  • 1级: file :config/application.yml 【最高】

  • 2级: file :application.yml

  • 3级:classpath:config/application.yml

  • 4级:classpath:application.yml 【最低】

  • 作用:

    • 1级与2级留做系统打包后设置通用属性- 3级与4级用于系统开发阶段设置通用属性

三、整合第三方技术

1. 整合JUnit

问题导入

回忆一下Spring整合JUnit的步骤?

1.1 Spring整合JUnit(复习)

1.2 SpringBoot整合JUnit

【第一步】添加整合junit起步依赖(可以直接勾选)

  1. <dependency>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-test</artifactId>
  4. <scope>test</scope>
  5. </dependency>

【第二步】编写测试类,默认自动生成了一个

  1. @SpringBootTest
  2. class Springboot07JunitApplicationTests {
  3. @Autowired
  4. private BookService bookService;
  5. @Test
  6. public void testSave() {
  7. bookService.save();
  8. }
  9. }

2. 基于SpringBoot实现SSM整合

问题导入

回忆一下Spring整合MyBatis的核心思想?

2.1 Spring整合MyBatis(复习)
  • SpringConfig

    • 导入JdbcConfig
    • 导入MyBatisConfig
  1. @Configuration
  2. @ComponentScan("com.itheima")
  3. @PropertySource("classpath:jdbc.properties")
  4. @Import({JdbcConfig.class, MyBatisConfig.class})
  5. public class SpringConfig {
  6. }
  • JDBCConfig

    • 定义数据源(加载properties配置项:driver、url、username、password)
  1. #jdbc.properties
  2. jdbc.driver=com.mysql.jdbc.Driver
  3. jdbc.url=jdbc:mysql://localhost:3306/spring_db
  4. jdbc.username=root
  5. jdbc.password=itheima
  1. public class JdbcConfig {
  2. @Value("${jdbc.driver}")
  3. private String driver;
  4. @Value("${jdbc.url}")
  5. private String url;
  6. @Value("${jdbc.username}")
  7. private String userName;
  8. @Value("${jdbc.password}")
  9. private String password;
  10. @Bean
  11. public DataSource getDataSource() {
  12. DruidDataSource ds = new DruidDataSource();
  13. ds.setDriverClassName(driver);
  14. ds.setUrl(url);
  15. ds.setUsername(userName);
  16. ds.setPassword(password);
  17. return ds;
  18. }
  19. }
  • MyBatisConfig - 定义SqlSessionFactoryBean- 定义映射配置
  1. @Bean
  2. public SqlSessionFactoryBean getSqlSessionFactoryBean(DataSource dataSource) {
  3. SqlSessionFactoryBean ssfb = new SqlSessionFactoryBean();
  4. ssfb.setTypeAliasesPackage("com.itheima.domain");
  5. ssfb.setDataSource(dataSource);
  6. return ssfb;
  7. }
  1. @Bean
  2. public MapperScannerConfigurer getMapperScannerConfigurer() {
  3. MapperScannerConfigurer msc = new MapperScannerConfigurer();
  4. msc.setBasePackage("com.itheima.dao");
  5. return msc;
  6. }
2.2 SpringBoot整合MyBatis
  • SpringBoot整合Spring(不存在)

  • SpringBoot整合SpringMVC(不存在)

  • SpringBoot整合MyBatis(主要)

①:创建新模块,选择Spring初始化,并配置模块相关基础信息

②:选择当前模块需要使用的技术集(MyBatis、MySQL)

③:设置数据源参数

  1. spring:
  2. datasource:
  3. driver-class-name: com.mysql.cj.jdbc.Driver
  4. url: jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC
  5. username: root
  6. password: root
  7. type: com.alibaba.druid.pool.DruidDataSource

注意事项:

  1. SpringBoot版本低于2.4.3(不含),Mysql驱动版本大于8.0时,需要在url连接串中配置时区,或在MySQL数据库端配置时区解决此问题
  1. jdbc:mysql://localhost:3306/ssm_db?serverTimezone=UTC

④:定义数据层接口与映射配置

  1. @Mapper
  2. public interface UserDao {
  3. @Select("select * from tbl_book where id=#{id}")
  4. Book getById(Integer id);
  5. }

⑤:测试类中注入dao接口,测试功能

  1. @SpringBootTest
  2. class Springboot08MybatisApplicationTests {
  3. @Autowired
  4. private BookDao bookDao;
  5. @Test
  6. public void testGetById() {
  7. Book book = bookDao.getById(1);
  8. System.out.println(book);
  9. }
  10. }
2.3 案例-SpringBoot实现ssm整合

【第一步】创建SpringBoot工程,添加druid依赖

  1. <!-- todo 1 添加druid连接池依赖-->
  2. <dependency>
  3. <groupId>com.alibaba</groupId>
  4. <artifactId>druid</artifactId>
  5. <version>1.2.6</version>
  6. </dependency>

【第二步】复制springmvc_ssm各种资源(主java类、页面、测试类)

【第三步】删除config包中的所有配置,在BookDao接口上加@Mapper注解

  1. //todo 3 在BookDao接口上加@Mapper注解,让SpringBoot给接口创建代理对象
  2. @Mapper
  3. public interface BookDao {
  4. //...
  5. }

【第四步】将application.properties修改成application.yml,配置端口号和连接参数

  1. server:
  2. port: 80
  3. # todo 4 配置数据库连接参数
  4. spring:
  5. datasource:
  6. driver-class-name: com.mysql.cj.jdbc.Driver
  7. url: jdbc:mysql://localhost:3306/ssm_db
  8. username: root
  9. password: root
  10. type: com.alibaba.druid.pool.DruidDataSource

【第五步】修改BookServiceTest配置类,进行配置

  1. // todo 5 修改单元测试类,添加@SpringBootTest主键,修复@Test注解导包
  2. @SpringBootTest
  3. public class BookServiceTest {
  4. @Autowired
  5. private BookService bookService;
  6. @Test
  7. public void testGetById(){
  8. Book book = bookService.getById(2); //传递参数1会抛出异常
  9. System.out.println(book);
  10. }
  11. @Test
  12. public void testGetAll(){
  13. List<Book> all = bookService.getAll();
  14. System.out.println(all);
  15. }
  16. }

【第六步】在static目录中提供index.html页面,跳转到"pages/books.html"

  1. <script>
  2. location.href="pages/books.html"
  3. </script>

最后:运行引导类即可访问

标签: spring boot java spring

本文转载自: https://blog.csdn.net/2301_80237574/article/details/143166744
版权归原作者 技术瞭望台 所有, 如有侵权,请联系我们删除。

“【Spring Boot实战教程】第一章——多环境配置与第三方技术整合”的评论:

还没有评论