SpringBoot概述
概念
- SpringBoot提供了一种快速使用Spring的方式,基于约定优于配置的思想,可以让开发人员不必在配置与逻
辑业务之间进行思维的切换,全身心的投入到逻辑业务的代码编写中,从而大大提高了开发的效率,一定程度
上缩短了项目周期。2014 年 4 月,Spring Boot 1.0.0 发布。Spring的顶级项目之一(https://spring.io)。
Spring 缺点
1.配置繁琐
- 虽然Spring的组件代码是轻量级的,但它的配置却是重量级的。一开始,Spring用XML配置,而且是很多
XML配置。Spring 2.5引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式XML配置。
Spring 3.0引入了基于Java的配置,这是一种类型安全的可重构配置方式,可以代替XML。
2.依赖繁琐
- 项目的依赖管理也是一件耗时耗力的事情。在环境搭建时,需要分析要导入哪些库的坐标,而且还需要分析导
入与之有依赖关系的其他库的坐标,一旦选错了依赖的版本,随之而来的不兼容问题就会严重阻碍项目的开发
进度。
SpringBoot功能
1.自动配置
- SpringBoot的自动配置是一个运行时(更准确地说,是应用程序启动时)的过程,考虑了众多因素,才决定Spring配置应该用哪个,不该用哪个。该程序过程是SpringBoot自动完成的。
2.起步依赖
- 起步依赖本质上是一个Maven项目对象模型(Project Object Model,POM),定义了对其他库的传递依赖,这些东西加在一起即支持某项功能。
简单的说,起步依赖就是将具备某种功能的坐标打包到一起,并提供一些默认的功能。
3.辅助功能
- 提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。
Spring Boot 并不是对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式
二.SpringBoot快速入门
1.实现步骤
① 创建Maven项目
② 导入SpringBoot起步依赖
<!-- Inherit defaults from Spring Boot -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.9.RELEASE</version>
</parent>
<!-- Add typical dependencies for a web application -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<!-- Package as an executable jar -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
③ 定义Controller
@RestController
public class HelloController {
@RequestMapping("/hello")
public String hello(){
return "hello Spring Boot !";
}
}
④ 编写引导类
/*
* 引导类。SpringBoot项目的入口
* */
@SpringBootApplication
public class HelloApplication {
public static void main(String[] args){
SpringApplication.run(HelloApplication.class,args);
}
}
⑤ 启动测试
三.SpringBoot配置
3.1 配置文件分类
SpringBoot是基于约定的,所以很多配置都有默认值,但如果想使用自己的配置替换默认配置的话,就可以使用
application.properties或者application.yml(application.yaml)进行配置。
properties:
server.port=8080
yml:
server:
port: 8080
⚫ SpringBoot提供了2种配置文件类型:properteis和yml/yaml
⚫ 默认配置文件名称:application
⚫ 在同一级目录下优先级为:properties > yml > yaml
3.2 yaml
YAML全称是 YAML Ain’t Markup Language 。YAML是一种直观的能够被电脑识别的的数据数据序列化格式,并且容易被人类阅读,容易和脚本语言交互的,可以被支持YAML库的不同的编程语言程序导入,比如: C/C++, Ruby, Python,Java, Perl, C#, PHP等。YML文件是以数据为核心的,比传统的xml方式更加简洁。
YAML文件的扩展名可以使用.yml或者.yaml。
- 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
简洁,以数据为核心
3.2.1 YAML:基本语法
- 大小写敏感
数据值前边必须有空格,作为分隔符
使用缩进表示层级关系
缩进不允许使用Tab键,只允许使用空格。
#表示注释,从这个字符到尾会被注释掉。
3.2.2 YAML:数据格式
- 对象(map):键值对的集合
person:
name: zhangsan
#行内写法
person: {name: zhangsan}
- 数组:一组按次序排序的值
address:
- beijing
- shanghai
#行内写法
address: [beijing,shanghai]
- 纯量: 单个的,不可再分的值
msg1: 'hello \n world' #单引忽略转义字符
msg2: "hello \n world" #双引识别转义字符
- yaml:参数引用
name: lisi
person:
name: ${name} #引用上边定义的name值
3.3 读取配置文件内容
application.yml
server:
port: 8080
name: abc
#对象
person:
name: zhangsan
age: 20
#数组
address:
- beijing
- shanghai
//1.@Value
//单个注入
@Value("${name}")
private String name;
//2.Environment类的实例存放的时spring容器的配置信息
@Autowired
private Environment env; //使用的是 org.springframework.core.env
//调用
System.out.println(env.getProperty("person.name"));
//3.@ConfigurationProperties
@Component //创建对象,实例化到spring容器中
@ConfigurationProperties(prefix = "person")
public class Person{
private String name;
private int age;
private String[] address;
}
加入依赖,写配置文件的时候可以提示
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
3.4 profile
我们在开发Spring Boot应用时,通常同一套程序会被安装到不同环境,比如:开发、测试、生产等。其中数据库地址、服务器端口等等配置都不同,如果每次打包时,都要修改配置文件,那么非常麻烦。profile功能就是来进行动态配置切换的。
3.4.1 profile配合方式
- 多profiles文件方式
application.properties
spring.profiles.active=pro(dev,pro,test写的哪个就用哪个的数据)
application-dev.properties
server.port=8082
application-pro.properties
server.port=8083
application-test.properties
server.port=8084
- yml多文档方式 — 分隔不同配置
---
server:
port: 8081
spring:
profiles: dev
---
server:
port: 8082
spring:
profiles: test
---
server:
prot: 8083
spring:
profiles: pro
---
spring:
profiles:
active: pro
3.4.2 profile激活方式
- 配置文件
- 虚拟机参数
使用ideal - 命令行参数
java-jar xxx.jar --spring.profiles.active=dev
3.5 内部配置加载顺序
- file:./config/:当前项目下的/config目录下
- file:./ :当前项目的根目录
- classpath:/config/:classpath的/config目录
- classpath:/ :classpath的根目录
加载顺序为上文的排列顺序,高优先级配置的属性会生效
四.SpringBoot整合其他框架
4.1 SpringBoot整合Junit
① 搭建SpringBoot工程
② 引入starter-test起步依赖
③ 编写测试类
④ 添加测试相关注解
/*
* userService的测试类
* */
@SpringBootTest(classes = SpringbootTestApplication.class)
class UserServiceTest {
@Autowired
private UserService userService;
@Test
public void testadd() {
userService.add();
}
}
⑤ 编写测试方法
4.2 SpringBoot整合Redis
① 搭建SpringBoot工程
② 引入redis起步依赖
③ 配置redis相关属性
④ 注入RedisTemplate模板
⑤ 编写测试方法,测试
@SpringBootTest
class SpringbootRedisApplicationTests {
@Autowired
private RedisTemplate redisTemplate;
@Test
public void testSet() {
//存入数据
redisTemplate.boundValueOps("name").set("zhangsan");
}
@Test
public void testGet(){
//获取数据
Object name = redisTemplate.boundValueOps("name").get();
System.out.println(name);
}
}
4.3 SpringBoot整合Mybatis
① 搭建SpringBoot工程
② 引入mybatis起步依赖,添加mysql驱动
③ 编写DataSource和MyBatis相关配置
#dataSource
spring:
datasource:
url: jdbc:mysql:///springboot
username: root
password: 333
driver-class-name: com.mysql.jdbc.Driver
#mybatis
mybatis:
mapper-locations: classpath:mapper/*Mapper.xml #mapper映射文件路径
type-aliases-package: com.tx.springbootmybatis.domain
#config-locations: #指定mybatis的核心配置文件
④ 定义表和实体类
⑤ 编写dao和mapper文件/纯注解开发
@Mapper
public interface UserMapper {
@Select("select * from t_user")
public List<user> findAll();
}
⑥ 测试