SpringbootSpringBoot基础知识及整合Thymeleaf模板引擎
Posted 己不由心王道长
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SpringbootSpringBoot基础知识及整合Thymeleaf模板引擎相关的知识,希望对你有一定的参考价值。
文章目录
🌕博客x主页:己不由心王道长🌕!
🌎文章说明:spring🌎
✅系列专栏:spring
🌴本篇内容:对SpringBoot进行一个入门学习及对Thymeleaf模板引擎进行整合(对所需知识点进行选择阅读呀~)🌴
☕️每日一语:在人生的道路上,即使一切都失去了,只要一息尚存,你就没有丝毫理由绝望。因为失去的一切,又可能在新的层次上复得。☕️
🕤作者详情:作者是一名双非大三在校生,喜欢Java,欢迎大家探讨学习,喜欢的话请给博主一个三连鼓励。🕤
🚩 交流社区:己不由心王道长(优质编程社区)
SpringBoot简介
SpringBoot是什么
①Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
为什么要学习SpringBoot
一、SpringBoot能简化配置、从 2002 年开始,Spring 一直在飞速的发展,如今已经成为了在Java EE(Java Enterprise Edition)开发中真正意义上的标准,但是随着技术的发展,Java EE使用 Spring 逐渐变得笨重起来,大量的 XML 文件存在于项目之中。
SpringBoot的优势
1、减少开发,测试时间和努力。
2、使用JavaConfig有助于避免使用XML。
3、避免大量的Maven导入和各种版本冲突。
4、提供意见发展方法。
5、通过提供默认值快速开始开发。
6、没有单独的Web服务器需要。这意味着你不再需要启动Tomcat,Glassfish或其他任何东西。
学习SpringBoot前要具备的基础
声明:这不是在劝退,而是在告诉同志们,学习是一个循序渐进的过程,不可操之过急。一步一个脚印的走,才能到达终点站。
学习这个知识点你应该具备的一些基础知识:
基础篇:javase基础,包括但不限于:面向对象,封装,继承,多态,类与接口,集合,IO等等。
基础篇:Spring、SpringMVC:知道Spring是用来管理bean,能够基于Restful实现页面请求交互功能
基础篇:熟练掌握Mybatis
创建第一个SpringBoot项目
在Spring官方下创建SpringBoot项目
一、打开Spring官方—>projects—>SpringBoot—>Spring initializr;
或者点击创建SpringBoot看到以下图片:
按照上述图片完成后执行第7步会下载一个压缩包:
二、找到压缩包位置解压
三、导入创建好的SpringBoot项目
打开IEDA:file—>open:找到刚才文件解压位置,加载进来即可
或者直接把解压好的文件拖进IDEA也可以:
如图:
使用IDEA创建SpringBoot项目
说明:我们一般是不会在Spring的官网上创建SpringBoot项目的,而是使用IDEA创建项目,因为IEDA为我们准备好了创建工具,这样的创建更加省时省力。
一、打开IEDA新建一个项目,就叫做SpringBoot:
二、在项目里新建一个modules,取名为SpringBoot-demo1
在上面点击Next之后,跳到下面图片
选中之后点击finish—>apply—>ok即可
三、编写测试程序
在Application尝试输出一段话,检查一下代码系统是否正确:
package com.example.springbootdemo1;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SpringBootDemo1Application
public static void main(String[] args)
SpringApplication.run(SpringBootDemo1Application.class, args);
System.out.println("鸡到底美不美?");
很明显,我们创建的第一个SpringBoot成功了。
SpringBoot配置文件详解
属性配置
一、 我们可以看到,SpringBoot项目下的Resources目录下有一个application.properties的配置文件,SpringBoot通过配置文件application.properties就可以修改默认的配置,什么意思呢?举个例子,因为SpringBoot采用的是内嵌tomcat的方式,所以默认端口是8080,我现在通过application.properties配置文件把8080修改为8081:
server.port=8081
执行测试:可以看到端口号已经由8080变为8081
上述例子说明了application.properties配置文件可以更改SpringBoot提供的默认配置,设置成我们实际需要的配置。
配置文件分类
SpringBoot使用一个全局的配置文件,配置文件名是固定的(都必须是application.开头),支持三种格式(properties、yaml、yml),由于properties类型的我们已经用过很多,这里就不再过多赘述,这里介绍一下yaml或者yml。
一、创建application.yaml、application.yml文件
yml:
yaml:
可以看到两者的用法和格式完全一样,那么是不是说两个作用一样呢?答案是两者一样,所以在使用过程中,我们一般选择yml格式
二、yml、yaml的注意点
1、以空格的缩进来控制层级关系,左对齐的一列数据,属于同一个层级
2、yaml、yml 格式:k: v,之间的空格必须有
3、k 和 v 对大小写敏感
4、k: v,字符串默认不用加上单引号或者双引号
5、在这两个配置文件中#表示注释
三、yml中各种数据类型的使用
对象、map类:
普通写法:
Practitioner:
name: kunkun
age: 3
行内写法:
Practitioner: name: kunkun,age: 3
数组:
普通写法:
#缩略格式
Practitioner:
- name: kunkun
age:3
likes:
- sing
- dance
- rap
- basketball
- name: xiaoheizi
age: 4
likes:
- kunkun
- zhenxiatou
- suzhi666
行内写法:
Practitioner: [name: kunkun,age: 3,hobby: [sing,dance,rap,basketball],
name: xiaoheizi,age: 4,hobby: [kunkun,zhenxiatou,suzhi666]]
四、配置文件读取
1、读取单个数据
package com.example.springbootdemo1.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
/**
* @author 不止于梦想
* @date 2022/10/21 21:12
*/
@RestController
public class indexController
@Value("$name")
public String username;
@ResponseBody
@RequestMapping("/index")
public String welcomeView()
ModelAndView mv = new ModelAndView();
mv.addObject("user",username);
System.out.println(username);
return "hello";
//配置文件
name: kunkun
结果:
技巧:如果数据存在多层级,依次书写层级名称即可
注意:这里踩一个坑,我们在写配置文件的时候,一般都是key value键值对的,而key的值除非是你想要的,不然不要写成user,写成user系统会自动赋值为你系统的管理员:
#这里尝试验证
user:
name: kunkun
package com.example.springbootdemo1.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
/**
* @author 不止于梦想
* @date 2022/10/21 21:12
*/
@Controller
public class indexController
@Value("$user.name")
public String username;
@ResponseBody
@RequestMapping("/index")
public String welcomeView()
ModelAndView mv = new ModelAndView();
mv.addObject("user",username);
System.out.println(username.toString());
return "hello";
结果如下:
2、读取全部数据
提问:读取全部数据是使用@value标签给所有属性都注入值?
从上面我们可以看到,如果配置文件里的值是少量的,那么可以用@value标签给需要的属性赋值,但是在我们的日常开发中,配置文件的内容很多,一个一个注入得把我们累死!
解决方案:SpringBoot提供了一个对象,能够把所有的数据都封装到这一个对象中,这个对象叫做Environment,使用自动装配注解可以将所有的yaml数据封装到这个对象中
3、读取对象数据
因为Java是一个面向对象的语言,很多情况下,我们会将一组数据封装成一个对象。SpringBoot也提供了可以将一组yml对象数据封装一个Java对象的操作:
第一步:编写配置文件
student:
username: kunkun
age: 3
hobby: dance
第二步:编写一个对象类,并且将该对象类作为bean注入到Spring容器中,然后使用注解@ConfigurationProperties指定该对象加载哪一组yaml中配置的信息。
package com.example.springbootdemo1.pojo;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component//交给Spring容器保管
@ConfigurationProperties(prefix = "student")//对应的application.yml配置文件的位置
public class Student
private String username;
private int age;
private String hobby;
@Override
public String toString()
return "Student" +
"username='" + username + '\\'' +
", age=" + age +
", hobby='" + hobby + '\\'' +
'';
public String getUsername()
return username;
public void setUsername(String username)
this.username = username;
public int getAge()
return age;
public void setAge(int age)
this.age = age;
public String getHobby()
return hobby;
public void setHobby(String hobby)
this.hobby = hobby;
public Student()
public Student(String username, int age, String hobby)
this.username = username;
this.age = age;
this.hobby = hobby;
第三步,编写测试类
package com.example.springbootdemo1;
import com.example.springbootdemo1.pojo.Student;
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
class SpringBootDemo1ApplicationTests
@Autowired
private Student student;
@Test
void contextLoads()
System.out.println(student);
测试结果如下:
总结:@value和@ConfigurationProperties都是获取配置文件信息的;@value常用在获取单个或者少量的配置文件,而后者常需要对应配置文件属性的封装类,即把文件属性映射写成一个封装的类,并把类交给spring管理(常配合Component使用)。然后使用@ConfigurationProperties添加前缀以对应起来配置文件的属性。
SpringBoot整合Thymeleaf模板引擎
Thymeleaf简介
一、Thymeleaf是一个流行的模板引擎,该模板引擎采用Java语言开发,模板引擎是一个技术名词,是跨领域跨平台的概念,在Java语言体系下有模板引擎,在C#、PHP语言体系下也有模板引擎。除了thymeleaf之外还有Velocity、FreeMarker等模板引擎,功能类似
二、Thymeleaf的主要目标是将优雅的自然模板带到您的开发工作流程中—HTML能够在浏览器中正确显示,并且可以作为静态原型,从而在开发团队中实现更强大的协作。Thymeleaf能够处理HTML,XML,JavaScript,CSS甚至纯文本。
三、Thymeleaf的主要目标是提供一个优雅和高度可维护的创建模板的方式。 为了实现这一点,它建立在自然模板的概念之上,以不影响模板作为设计原型的方式将其逻辑注入到模板文件中。 这改善了设计沟通,弥合了前端设计和开发人员之间的理解偏差。
示例:Thymeleaf 通过在 html 标签中,增加额外属性来达到“模板+数据”的展示方式,示例代码如下。
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org"><!--引入thymeleaf命名空间-->
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--th:text 为 Thymeleaf 属性,用于在展示文本-->
<h1 th:text="欢迎来到Thymeleaf">欢迎访问静态页面</h1>
</body>
</html>
当直接使用浏览器打开时,浏览器展示结果如下。
欢迎来到Thymeleaf
当通过 Web 应用程序访问时,浏览器展示结果如下。
欢迎访问静态页面
整合
SpringBoot整合Thymeleaf需要三个步骤:
一、引入对应Thymeleaf的starter,其实在以后的整合中,要整合什么技术,就引入该技术的starter即可:
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-thymeleaf -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
<version>2.7.3</version>
</dependency>
二、创建模板文件,并放在指定目录下
2.1 由于 SpringBoot 为 thymeleaf 提供了一整套的自动化配置方案,我们几乎不用做任何更改就可以直接使用,如下是SpringBoot中thymeleaf的默认配置
@ConfigurationProperties(prefix = "spring.thymeleaf")
public class ThymeleafProperties
private static final Charset DEFAULT_ENCODING = StandardCharsets.UTF_8;
public static final String DEFAULT_PREFIX = "classpath:/templates/";
public static final String DEFAULT_SUFFIX = ".html";
/**
* Whether to check that the template exists before rendering it.
*/
private boolean checkTemplate = true;
/**
* Whether to check that the templates location exists.
*/
private boolean checkTemplateLocation = true;
/**
* Prefix that gets prepended to view names when building a URL.
*/
private String prefix = DEFAULT_PREFIX;
/**
* Suffix that gets appended to view names when building a URL.
*/
private String suffix = DEFAULT_SUFFIX;
/**
* Template mode to be applied to templates. See also Thymeleaf's TemplateMode enum.
*/
private String mode = "HTML";
...
通过 org.springframework.boot.autoconfigure.thymeleaf.ThymeleafProperties 找到 SpringBoot 中 thymeleaf 的默认配置:
@ConfigurationProperties //这个注解熟不熟悉,这不就是上面的读取配置文件注入的注解吗? DEFAULT_ENCODING :默认字符编码,为utf-8 DEFAULT_PREFIX 默认前缀表达式,值为"classpath:/templates/",即类路径下的templates,对应了SpringBoot项目下的Resource下的templates。 DEFAULT_SUFFIX 后缀表达式,默认为.html
从上面代码可以看出,thymeleaf 模板文件默认放在 resources/templates 目录下,默认的后缀是 .html。
当然,我们有时候不想用默认配置,因为需求是多样的,这个时候SpringBoot也是提供了个性化的方法供我们使用。;
在SpringBoot配置文件中:
spring:
#thymeleaf模板引擎
thymeleaf:
#是否开启缓存
cache: false
#编码格式
encoding: UTF-8
这里我把缓存关闭,就能使页面进行实时的更新。
三、整合thymeleaf 模板引擎
上面已经把starter导入了,然后配置了thymeleaf,接下来编写测试
编写一个Controller:
package com.example.springbootdemo1.controller;
import com.example.springbootdemo1.pojo.User;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.ModelAndView;
import java.util.ArrayList;
import java.util.List;
/**
* @author 不止于梦想
* @date 2022/10/21 21:12
*/
@RestController
public class indexController
@RequestMapping("/index")
public ModelAndView indexView()
ModelAndView mv = new ModelAndView();
List<User> userList = new ArrayList<>();
for(int i=0;i<5;i++)
User user = new User("zhangsan"+i,5+i);
userList.add(user);
mv.addObject("user",userList);
mv.setViewName("index");
return mv;
编写要跳转的index.html界面
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org"><!--引入thymeleaf命名空间-->
<head>
<meta charset="UTF-8">
<title>Title</title>74
</head>
<body>
<table border="1">
<tr>
<td>用户姓名</td>
<td>用户年龄</td>
</tr>
<tr th:each="item : $userList">
<td th:text="$item.userName"></td>
<td th:text="$item.userAge"></td>
</tr>
</table>
</body>
</html>
在配置文件中,编写视图解析器:
spring:
#thymeleaf模板引擎
thymeleaf:
#是否开启缓存
cache: false
#编码格式
encoding: UTF-8
mvc:
view:
prefix: /pages/
suffix: .html
总结
SpringBoot是一门十分重要的技术,而学习这门技术有一定的门槛,需要我们掌握Spring技术栈的相关东西,而Spring Boot对于后面分布式的服务又是至关重要的,SpringCloud是在Spring SpringBootSpringBoot配置文件及YAML简介
SpringBoot配置文件
SpringBoot使用一个全局的配置文件,配置文件名是固定的;
- application.properties
- application.yml
配置文件的作用:修改SpringBoot自动配置的默认值; SpringBoot在底层就自动配置好;
配置文件加载位置
1、springboot 启动会扫描以下位置的application.properties或者application.yml文件作为Spring boot的默认配置文件
1 –file:./config/ 2 –file:./ 3 –classpath:/config/ 4 –classpath:/ 优先级由高到底,高优先级的配置会覆盖低优先级的配置;
SpringBoot会从这四个位置全部加载主配置文件;互补配置;
2、可以通过spring.config.location来改变默认的配置文件位置
项目打包好以后,我们可以使用命令行参数的形式,启动项目的时候来指定配置文件的新位置;指定配置文件和默认加载的这些配置文件共同起作用形成互补配置;
命令:java -jar spring-boot-config-1.0-SNAPSHOT.jar --spring.config.location=application.properties
3、外部配置加载顺序
SpringBoot也可以从以下位置加载配置; 优先级从高到低;高优先级的配置覆盖低优先级的配置,所有的配置会形成互补配置
1 1.命令行参数 所有的配置都可以在命令行上进行指定 2 java -jar spring-boot-config-1.0-SNAPSHOT.jar --server.port=8087 -- server.context-path=/abc 多个配置用空格分开; --配置项=值 3 2.来自java:comp/env的JNDI属性 4 3.Java系统属性(System.getProperties()) 5 4.操作系统环境变量 6 5.RandomValuePropertySource配置的random.*属性值由jar包外向jar包内进行寻找; 7 8 优先加载带profile 9 6.jar包外部的application-{profile}.properties或application.yml(带spring.profile)配置文件 10 7.jar包内部的application-{profile}.properties或application.yml(带spring.profile)配置文件 11 12 再来加载不带profile 13 8.jar包外部的application.properties或application.yml(不带spring.profile)配置文件 14 9.jar包内部的application.properties或application.yml(不带spring.profile)配置文件 15 10.@Configuration注解类上的@PropertySource 16 11.通过SpringApplication.setDefaultProperties指定的默认属性 所有支持的配置加载来源;
YAML简介
AML(YAML Ain\'t Markup Language)
YAML A Markup Language:是一个标记语言
YAML isn\'t Markup Language:不是一个标记语言;
标记语言:以前的配置文件; 大多都使用的是 xxxx.xml文件; YAML:以数据为中心,比json、xml等更适合做配置文件;
YAML:配置例子
1 server: 2 port: 8081
properties文件:
1 server.port= 8081
YAML语法
1、基本语法
k:(空格)v
表示一对键值对(空格必须有); 以空格的缩进来控制层级关系;只要是左对齐的一列数据,都是同一个层级的;
属性和值也是大小写敏感;
1 server: 2 port: 8081 3 path: /hello
2、值的写法
字面量:普通的值(数字,字符串,布尔)
k: v == 字面直接来写;
字符串默认不用加上单引号或者双引号;
"":双引号; 不会转义字符串里面的特殊字符; 特殊字符会作为本身想表示的意思 name: "zhangsan \\n lisi":输出;zhangsan 换行 lisi
\'\':单引号; 会转义特殊字符,特殊字符最终只是一个普通的字符串数据 name: ‘zhangsan \\n lisi’:输出;zhangsan \\n lisi
对象、Map(属性和值)(键值对):
k: v == 在下一行来写对象的属性和值的关系;注意缩进
对象还是k: v的方式
1 friends: 2 lastName: zhangsan 3 age: 20
行内写法:
1 friends: {lastName:zhangsan, age:18}
数组(List、Set):
用- 值表示数组中的一个元素
1 pets: 2 ‐cat 3 ‐dog 4 ‐pig
行内写法
1 pets: [cat,dog,pig]
配置文件值注入
配置文件
1 person: 2 lastName: hello 3 age: 18 4 boss: false 5 birth: 2017/12/12 6 maps: {k1: v1,k2: 12} 7 lists: 8 ‐ lisi 9 ‐ zhaoliu 10 dog: 11 name: 小狗 12 age: 12
javaBean
1 /** 2 * 将配置文件中配置的每一个属性的值,映射到这个组件中 3 * @ConfigurationProperties 将本类中的所有属性和配置文件中相关的配置进行绑定; 4 * prefix = "person" : 配置文件中哪个下面的所有属性 5 * 只有这个组件是容器中的组件,此啊能使用容器提供的@ConfigurationProperties功能 6 * 7 */ 8 // @PropertySource(value = {"classpath:person.properties"}) 9 @Component 10 @ConfigurationProperties(prefix = "person") 11 public class Person { 12 13 private String lastName; 14 private Integer age; 15 private Boolean boss; 16 private Date birth; 17 18 private Map<String, Object> maps; 19 private List<Object> lists; 20 21 private Dog dog;
注意:导入配置文件处理器,即pom文件中增加下面依赖,以后在编写配置文件时就有提示了
1 <!-- 导入配置文件处理器,配置文件进行绑定会有提示 --> 2 <dependency> 3 <groupId>org.springframework.boot</groupId> 4 <artifactId>spring-boot-configuration-processor</artifactId> 5 <optional>true</optional> 6 </dependency>
a、*.properties文件乱码问题,idea中默认utf-8可能会乱码,调整settings
b、@Value获取值和@ConfigurationProperties获取值比较
@ConfigurationProperties |
@Value |
|
功能 |
批量注入配置文件中的属性 |
一个个指定 |
松散绑定(松散语法) |
支持 |
不支持 |
SpEL |
不支持 |
支持 |
JSR303数据校验 |
支持 |
不支持 |
复杂类型封装 |
支持 |
不支持 |
配置文件yml还是properties他们都能获取到值;
如果说,只是在某个业务逻辑中需要获取一下配置文件中的某项值,使用@Value;
如果说,专门编写了一个javaBean来和配置文件进行映射,我们就直接使用@ConfigurationProperties;
c、配置文件注入值数据校验
1 @Component 2 @ConfigurationProperties(prefix = "person") 3 @Validated 4 public class Person { 5 6 //lastName必须是邮箱格式 7 @Email //@Value("${person.last‐name}") 8 private String lastName; 9 //@Value("#{11*2}") 10 private Integer age; 11 //@Value("true") 12 private Boolean boss; 13 private Date birth; 14 private Map<String,Object> maps; 15 private List<Object> lists; 16 private Dog dog;
d、@PropertySource&@ImportResource&@Bean
@PropertySource: 加载指定的配置文件;
1 @Component 2 @ConfigurationProperties(prefix = "person") 3 @PropertySource(value={"classpath:person.properties"}) 4 public class Person {
@ImportResource: 导入Spring的配置文件,让配置文件里面的内容生效;
Spring Boot里面没有Spring的配置文件,我们自己编写的配置文件,也不能自动识别;
想让Spring的配置文件生效,加载进来;@ImportResource标注在一个配置类上
1 // 导入Spring的配置文件让其生效 2 @ImportResource(locations={"classpath:beans.xml"})
SpringBoot推荐给容器中添加组件的方式;推荐使用全注解的方式
1、配置类@Configuration------>Spring配置文件
2、使用@Bean给容器中添加组件
1 /** 2 * @Configuration:指明当前类是一个配置类:就是用来替代之前的Spring配置文件 3 * 4 * 在配置文件中用<bean></bean>标签添加的组件 5 */ 6 @Configuration 7 public class MyAppConfig { 8 9 /** 10 * 将方法的返回值添加到容器中 11 * 容器中这个组件的ID就是方法名 12 */ 13 @Bean 14 public HelloService helloService02(){ 15 System.out.println("配置类@Bean给容器添加组件。。。"); 16 return new HelloService(); 17 } 18 }
配置文件占位符
1、随机数
1 ${random.value}、${random.int}、${random.long} 2 ${random.int(10)}、${random.int[1024,65536]}
2、占位符获取之前配置的值,如果没有可以是用:指定默认值
1 person.last‐name=张三${random.uuid} 2 person.age=${random.int} 2 person.birth=2017/12/15 3 person.boss=false 4 person.maps.k1=v1 5 person.maps.k2=14 6 person.lists=a,b,c 7 person.dog.name=${person.hello:hello}_dog 8 person.dog.age=15
Profile文件
1、多Profile文件
在主配置文件编写的时候,文件名可以是 application-{profile}.properties/yml
默认使用application.properties的配置;
2、yml支持多文档块方式
1 server: 2 port: 8081 3 spring: 4 profiles: 5 active: prod 6 ‐‐‐ server: 7 port: 8083 8 spring: 9 profiles: dev 10 ‐‐‐ 11 server: 12 port: 8084 13 spring: 14 profiles: prod #指定属于哪个环境
3、激活指定profile文件
a、在配置文件中指定 spring.profiles.active=dev
b、命令行: java -jar spring-boot-1.0-SNAPSHOT.jar --spring.profiles.active=dev; 可以直接在测试的时候,配置传入命令行参数
c、虚拟机参数; -Dspring.profiles.active=dev
以上是关于SpringbootSpringBoot基础知识及整合Thymeleaf模板引擎的主要内容,如果未能解决你的问题,请参考以下文章
SpringBootspringboot 与 Email 邮箱