--课程大纲
1.什么是springboot以及springboot的特点
2.快速搭建springboot项目
3.springboot常用的配置文件的类型
4.读取springboot配置文件种的内容
5.多环境配置
6.springboot整合数据源-数据库连接池
7.springboot整合mybatis
1.什么是springboot以及springboot的特点
1.1 什么是springboot
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程 . 理解:spring框架搭建的步骤:[1]依赖 [2]配置文件。 使用springboot可以简化上面的两个步骤。
1.2 springboot的特点
1.创建独立的spring应用程序
2.嵌入Tomcat,不需要部署war文件
3.简化maven的配置
4.自动配置spring
5.提供生产就绪型功能,如指标,健康检查和外部配置
6.开箱即用,没有代码生成,也无需 xml 配置
2.使用idea快速搭建springboot工程
2.1在有网的情况下
创建一个controller包
@RestController public class HelloWordController { @RequestMapping("index") public Map<String , Object> hello(){ Map map = new HashMap(); map.put("name" , "wang"); map.put("age",80); return map; } }
浏览器访问接口
3.springboot常用的配置文件类型
properties和yml类型,他们的格式不同
两种类型不管使用哪一个,他们的名字必须是application,如果上面两个配置文件同时存在,而且里面的都有相同的配置,则properties的优先级要高于yml类型。
properties格式:
#修改端口号
server.port=8989
#修改上下文
server.servlet.context-path=/aaa
yml类型格式:
server:
port: 8887
servlet:
context-path:/bbb
4.如何读取配置文件种的内容
4.1 java为什么要读取配置文件中的内容,在开发时我们要把哪些内容放在配置文件中?
oss:上传文件,accessKeyId,accessKeySecret等 ,这些内容能写在java源代码中。硬编码格式, 不利于后期维护,我们需要把信息写入配置文件中。
4.2 读取方式有两种:
第一种方式:在类上@configurarionProperties(prefix="")
@Data
@Component
@ConfigurationProperties(prefix = "student")
public class Student {
private String name;
private String age;
private String address;
private List<String> hobby;
private Map<String, Object> map;
}
在properties配置文件
yml配置文件
controller层,可以直接获取
第二种 @value读取属性,只能读取基本的数据类型和string类型, 注解加在属性上
5.整合springboot数据源
--druid数据源---连接数据库
1.引入相关依赖
<!--mysql的驱动依赖-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.21</version>
</dependency>
2.配置数据源信息
#druid
#spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#spring.datasource.druid.url=jdbc:mysql://localhost:3306/db3
#spring.datasource.druid.username=root
#spring.datasource.druid.password=wenqing.
#spring.datasource.druid.initial-size=5
3.测试
@SpringBootTest
class Qy163SpringbootApplicationTests {
@Autowired
private DataSource dataSource;
@Test
void contextLoads() throws SQLException {
System.out.println(dataSource.getConnection());
}
}
6.springboot整合mybatis
1.相关依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.12.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.ykq</groupId>
<artifactId>qy163-springboot02</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>qy163-springboot02</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--mybatis和springboot整合的依赖 启动依赖-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.21</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
2.修改配置文件
#数据源
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql://localhost:3306/db3
spring.datasource.druid.username=root
spring.datasource.druid.password=wenqing.
#指定映射文件所在的路径--
mybatis.mapper-locations=classpath:mapper/*.xml
#mybatis日志文件
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
3.mapper接口
@Mapper
public interface StudentMapper {
/**
* 查询所有
*/
List<Student> findAll();
}
4.为mapper接口生成的代理实现类
@SpringBootApplication
public class Qy163SpringbootApplication {
public static void main(String[] args) {
SpringApplication.run(Qy163SpringbootApplication.class, args);
}
}
5.测试
@SpringBootTest
class Qy163Springboot3ApplicationTests {
@Autowired
private StudentMapper StudentMapper;
@Test
void contextLoads() {
StudentMapper.findAll();
}
}