Springboot框架
1.什么是spring boot框架
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程 . 理解:spring框架搭建的步骤:[1]依赖 [2]配置文件。 使用springboot可以简化上面的两个步骤。
2.spring boot的特点
(1)创建独立的Spring应用程序
(2)嵌入的Tomcat,无需部署WAR文件
(3)简化Maven配置
(4)自动配置Spring
(5)提供生产就绪型功能,如指标,健康检查和外部配置
(6)开箱即用,没有代码生成,也无需XML配置
3.快速搭建Springboot工程


点击完成后创建。


运行测试:创建一个controller包
@RestController //该类种所有方法的返回都是json格式
public class testController {
@GetMapping("ctrl")
public Map<String, Object> ctrl() {
HashMap<String, Object> map = new HashMap<>();
map.put("name", "ctrl");
map.put("hobby1", "c");
map.put("hobby2", "t");
map.put("hobby3", "r");
map.put("hobby4", "l");
return map;
}
}
运行结果:

4.Spring boot常用的配置文件类型
properties和yml格式。他们的区别就是格式上不同。
properties格式(全路径配置,更直观):

yml格式(简化路径配置,更简约):

注:使用yml格式时一定要注意冒号后面有一个空格!!!!!
注:不管使用哪个配置文件,他们的名字必须叫application. 如果上面两个配置文件同时存在,而且里面有相同的配置。则properties优先级高于yml优先级。
5.Java如何读取配置文件里的内容
java为什么需要读取配置文件的内容,我们开发时需要把哪些内容放入配置文件。
OSS:上传文件。accessKeyId,accessKeySecret等,这些内容能写在java源代码中。硬编码文件,不利维护。 我们需要把信息写入配置文件。
读取方式有两种:
第一种方式: 在类上@ConfigurationProperties(prefix="")
@Data
@Component
@ConfigurationProperties(prefix = "student")
public class Student {
private String name;
private Integer age;
private String address;
private List<String> hobby;
private Map<String,Object> map;
}
application.properties:

application.yml:

第二种使用@Value读取属性:---他只能读取基本类型和String类型。加在属性上
@Value("${student.map}")
private Map<String,Object> map;@GetMapping("a")
public Map<String,Object> a(){
return map;
}
6.Spring boot整合数据源
(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)application配置数据源信息
properties:
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql://localhost:3306/company?serverTimezone=Asia/Shanghai
spring.datasource.druid.username=root
spring.datasource.druid.password=root
spring.datasource.druid.initial-size=5
yml:
spring:
datasource:
druid:
url: jdbc:mysql://localhost:3306/work?serverTimezone=Asia/Shanghai
driver-class-name: com.mysql.cj.jdbc.Driver
username: root
password: 123456
(3)测试
@SpringBootTest
class Qy163Springboot01ApplicationTests {@Autowired
private DataSource dataSource;
@Test
void contextLoads() throws Exception{
System.out.println(dataSource);
}}
7.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.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.username=root
spring.datasource.druid.password=root
spring.datasource.druid.url=jdbc:mysql://localhost:3306/company#指定映射文件所在的路径--
mybatis.mapper-locations=classpath:mapper/*.xml#mybatis日志文件
mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
(3) mapper接口
public interface StudentMapper {
public List<Student> findAll();
}
(4)为mapper接口生成代理实现类

(5)测试
@SpringBootTest
class Demo4ApplicationTests {
@Autowired
private StudentMapper studentMapper;
@Test
void contextLoads() {
System.out.println(studentMapper.findAll());
}
}
(6)测试结果
