1.大纲-springboot框架
①. 什么是Springboot以及Springboot的特点。
②. 快速搭建springboot项目
③. springboot常用的配置文件类型.
④. 读取springboot配置文件的内容
⑤. 多环境配置
⑥. springboot整合数据源。
⑦. springboot整合mybatis.
2. 什么是Springboot以及Springboot的特点。
2.1 什么是springboot?
Spring Boot是 Spring 开源组织下的一个子项目,也是 Spring 组件一站式解决方案,主要是为了简化使用 Spring 框架的难度,简省繁重的配置。Spring Boot提供了各种组件的启动器(starters),开发者只要能配置好对应组件参数,Spring Boot 就会自动配置,让开发者能快速搭建依赖于 Spring 组件的 Java 项目。Spring Boot不但能创建传统的 war 包应用,还能创建独立的不依赖于任何外部容器(如:tomcat)的独立应用,使用 java -jar 命令就能启动。同时,Spring Boot也提供了一个命令行工具来执行 Spring 的脚本。
2.2 springboot特点
① 创建独立的 Spring 应用程序
② 嵌入的 Tomcat,无需部署 WAR 文件
③ 简化 Maven 配置
④ 自动配置 Spring
⑤ 提供生产就绪型功能,如指标,健康检查和外部配置
⑥ 开箱即用,没有代码生成,也无需 XML 配置
3.使用idea快速搭建springboot项目
3.1 测试
创建一个controller包
@RestController
public class HelloController {
@GetMapping("index")
public HashMap<String, Object> hello(){
HashMap<String, Object> map = new HashMap<>();
map.put("name","哈哈哈");
map.put("age", 20);
return map;
}
浏览器访问接口
4.pringboot常用的配置文件类型
properties和yml格式。他们的区别就是格式上不同。
properties格式如下:
1 # 修改端口号 默认8080
2 server.port=8888
3 # 修改路径
4 server.servlet.context-path=/aaa
yml格式如下:
1 server:
2 port: 8887
3 servlet:
4 context-path: /bbb
不管使用哪个配置文件,他们的名字必须叫application. 如果上面两个配置文件同时存在,而且里面有相同的配置。则properties优先级高于yml优先级。
5. java如何读取配置文件中的内容
读取方式有两种:
第一种方式:在实体类上加注解@ConfigurationProperties(prefix = “”)
@Data
@Component
@ConfigurationProperties(prefix = "")
public class Student {
private String name;
private Integer age;
private String address;
private List<String> hobby;
private Map<String,Object> map;
}
properties配置文件格式:
# 信息
student.name=zhangxueyou
student.age=18
student.address=zhengzhou
student.hobby[0]=swing
student.hobby[1]=reading
student.hobby[2]=sing
student.map.a=1
student.map.b=2
student.map.c=3
yml配置文件格式:
#信息
student:
name: Idh
age: 18
address: beijinghobby:
hobby:
- swing
- reading
- sing
map :
a:1
b:2
c:3
第二种方式:使用@Value读取属性: 他只能读取基本类型和String类型。加在属性上
新建两个配置文件config.properties和configs.properties,分别写入如下内容:
zhbin.config.web-configs.name=Java旅途
zhbin.config.web-configs.age=22
zhbin.config.web-configs.name=Java旅途
zhbin.config.web-configs.age=18
新增一个类用来读取配置文件
@Configuration
@PropertySource(value = {"classpath:config.properties"},encoding="gbk")
public class GetProperties {
@Value("${zhbin.config.web-configs.name}")
private String name;
@Value("${zhbin.config.web-configs.age}")
private String age;
public String getConfig() {
return name+"-----"+age;
}
}
6.多环境配置
多环境配置
7.springboot整合数据源
常用的主流开源数据库连接池有C3P0、DBCP、Tomcat Jdbc Pool、BoneCP、Druid等
我们使用druid数据源: ----连接数据库
1
(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) 配置数据源信息
#配置数据源信息
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql://localhost:3306/work?serverTimezone=Asia/Shanghai
spring.datasource.druid.username=root
spring.datasource.druid.password=123456
spring.datasource.druid.initial-size=6
测试
@SpringBootTest(classes = Qy163Springboot01Application.class)
class Qy163Springboot01ApplicationTests {
@Autowired
private DataSource dataSource;
@Test
void contextLoads() {
System.out.println(dataSource);
}
}
输出结果
{
CreateTime:"2023-04-11 11:03:04",
ActiveCount:0,
PoolingCount:6,
CreateCount:6,
DestroyCount:0,
CloseCount:0,
ConnectCount:0,
Connections:[
{ID:645717550, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"},
{ID:1620989914, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"},
{ID:1457352442, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"},
{ID:1298350375, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"},
{ID:221145867, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"},
{ID:521985523, ConnectTime:"2023-04-11 11:03:05", UseCount:0, LastActiveTime:"2023-04-11 11:03:05"}
]
}
8.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>
声明一下,web架构需要thymeleaf支持,而mybatis需要mybatis-spring-boot-starter支持.
(2) 配置文件
#数据源
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.username=root
spring.datasource.druid.password=123456
spring.datasource.druid.url=jdbc:mysql://localhost:3306/work
#指定映射文件所在的路径
mybatis.mapper-locations=classpath:mapper/*.xml
#mybatis日志文件
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
(3) 测试
新建pojo实体类,对应数据库的表
mapper层
public interface StudentMapper{
List<Student> findAll();
int insert(Student student);
int update(Student student);
int delete(Integer sId);
}
在resources目录下新建mapper目录,并在这个目录下新建StudentMapper.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.hm.mapper.StudentMapper">
<resultMap id="BaseResultMap" type="com.hm.pojo.Student">
<id property="sid" column="sid" jdbcType="INTEGER"/>
<result property="sname" column="sname" jdbcType="VARCHAR"/>
<result property="age" column="age" jdbcType="INTEGER"/>
<result property="cid" column="cid" jdbcType="INTEGER"/>
</resultMap>
<!--查询-->
<select id="findAll" resultMap="BaseResultMap">
select * from student
</select>
<!--增加-->
<insert id="insert">
insert into student(sid, sname, age, cid) VALUES (#{sid},#{sname},#{age},#{cid})
</insert>
<!--修改-->
<update id="update">
update student set cid=#{cid},sname=#{sname},age=#{age} where sid=#{sid}
</update>
<!--删除-->
<delete id="delete">
delete from student where sid=#{sId}
</delete>
</mapper>
在测试文件中测试
@SpringBootTest
class Qy163Springboot02ApplicationTests {
@Resource
private StudentMapper studentMapper;
@Test
void contextLoads() {
System.out.println(studentMapper.findAll());
}
@Test
void insert(){
Student student = new Student();
student.setSname("李榕轩");
student.setAge(99);
student.setSid(6);
student.setCid(2);
System.out.println(studentMapper.insert(student));
}
@Test
void update(){
studentMapper.update(new Student(5,"哈哈哈",56,1));
}
@Test
void delete(){
studentMapper.delete(6);
}
}