1.什么是springboot?
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。
2.springboot有什么特征?
(1)可以创建独立的应用程序,并且基于其Maven或Gradle插件,可以创建可执行的JARs和WARs;
(2)内嵌Tomcat或Jetty等Servlet容器;
(3)提供自动配置的“starter”项目对象模型(POMS)以简化Maven配置;
(4)尽可能自动配置Spring容器;
(5)提供准备好的特性,如指标、健康检查和外部化配置;
(6)绝对没有代码生成,不需要XML配置。
3.如何快速搭建Sprinboot工程
Next,
Ceate。
创建一个Controller包
@RestController
public class HellowWorldcontroller {
@GetMapping("/index")
public Map<String, Object> hellow(){
HashMap<String, Object> objectObjectHashMap = new HashMap<>();
objectObjectHashMap.put("name","cmx");
objectObjectHashMap.put("age",19);
return objectObjectHashMap;
}
浏览器访问接口:
4.Springboot常用的配置文件类型.
properties和yml格式。他们的区别就是格式上不同。
properties格式如下:
#修改端口号
server.prot=8080
#修改上下文路径
server.servlet.context-path=/aaa
.yml结构格式如下:
server:
prot: 8888
servlet:
context-path: /bbb
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;
}
properties:
student.name=hah
student.age=18
student.address=beijing
student.hobby[0]=swing
student.hobby[1]=reding
student.hobby[2]=sing
student.map.a=1
student.map.b=2
student.map.c=3
yml
student:
name:
age:
address:
hobby:
-swing
-reading
-sing
map:
a: 1
b: 2
c: 3
第二种使用@Value读取属性:---他只能读取基本类型和String类型。加在属性上
@Value("${student.map}")
private Map<String,Object> map;
@GetMapping("a")
public Map<String,Object> a(){
return map;
}
6. springboot整合数据源
(1)引入相关依赖
<dependencies>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.31</version>
</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>
</dependencies>
(2)在properties文件配置数据源
spring.datasource.druid.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.druid.url=jdbc:mysql://locaLhost:3306/mybatis_db
spring.datasource.druid.username=root
spring.datasource.druid.password=123456
spring.datasource.druid.initial-size=5
(3)测试
@SpringBootTest
class DemoApplicationTests {
@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.5.1</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.cmx</groupId>
<artifactId>demo5</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo5</name>
<description>demo5</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--swagger2依赖-->
<dependency>
<groupId>com.spring4all</groupId>
<artifactId>swagger-spring-boot-starter</artifactId>
<version>1.9.1.RELEASE</version>
</dependency>
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>swagger-bootstrap-ui</artifactId>
<version>1.7.8</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>
<dependency>
<groupId>com.fhs-opensource</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>4.0.5</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</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.url=jdbc:mysql://locaLhost:3306/mybatis_db
spring.datasource.username=root
spring.datasource.password=123456
#指定映射文件路径
mybatis.mapper-locations=classpath:mapper/*.xml
#Mybatis日志文件
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
(3)mapper接口
public interface StudentMapper {
List<Student> findAll();
}
(4)为mapper接口生成代理实现类
(5) 测试
@SpringBootTest
class Demo2ApplicationTests {
@Resource
private StudentMapper studentMapper;
@Test
public void findAll(){
System.out.println(studentMapper.findAll());
}