什么是Spring Boot?
Spring Boot是由Pivotal团队提供的全新框架,其设计的目的是用来简化新Spring的初始搭建和开发过程。该框架使用了特点的配置,不在需要开发人员定义样板化的配置了。通过这种方式,Spring Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
Spring boot简化了Spring的配置,将样板化的配置由注解来代替,大大的节省了搭建环境的时间。由于Spring Boot内置了Tomcat的所以也不用配置服务器了可以直接启动。
Spring Boot的特征
- 可以创建独立的Spring应用程序,并且基于Maven或Gradle插件
- 可以创建可执行的JAR包或者WAR包
- 内嵌Tomcat和Jetty、Undertow
- 绝对没有代码生成,不需要XML配置
- 可以构建任何东西
- 简单快捷安全
- 在idea中,使用Spring Initializr可以在几秒就构建一个springboot项目可以直接启动
- 提供自动配置的“starter”项目对象模型(POMS)以简化Maven配置
Spring Boot策略
开箱即用:
是指在开发过程中,通过Maven项目中pom文件导入的相关依赖,然后使用对应的注解来代替繁琐的XML配置以管理对象的生命周期。这个策略使得我们开发人员摆脱了复杂的配置工作以及管理工作。更着重于业务逻辑。
约定优于配置:
约定就是已经帮你默认配置好的逻辑,你只要拿来用就行了,不需要去xml配置了。比如一个属性有setter、getter,那我们用的时候就拿已经配置好的set和get就行了,这就是约定。springboot里面大部分的逻辑框架都封装了起来,都是直接拿来用或者用相关的注解都行。
Spring Boot快速开始
使用Spring Initializr创建SpringBoot工程
然后直接下一步 什么都不要选
然后打开pom文件编辑一下
给spring-boot-starter加上web(spring-boot-starter-web包含spring-boot-starter)
(中途重新创建了个项目 所以名字和上面不一样)
启动类
package com.example.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
* 程序启动类
*/
@SpringBootApplication
public class Demo1Application {
/**
* 程序启动入口
* @param args
*/
public static void main(String[] args) {
SpringApplication.run(Demo1Application.class, args);
}
}
@SpringBootApplication的三个核心类
-
@SpringBootConfiguration:在这个类的源码中又有一个Configuration的注解,@Configuration这个注解的作用就是声明当前类是一个配置类,然后Spring会自动扫描到添加了。@Configuration的类,读取其中的配置信息,而@SpringBootConfiguration是来声明当前类是SpringBoot应用的配置类,项目中只能有一个。所以一般我们无需自己添加。
-
@EnableAutoConfiguration:开启自动配置,告诉SpringBoot基于所添加的依赖,去“猜测”你想要如何配置Spring。比如我们引入了spring-boot-starter-web,而这个启动器中帮我们添加了tomcat、SpringMVC的依赖,此时自动配置就知道你是要开发一个web应用,所以就帮你完成了web及SpringMVC的默认配置了!我们使用SpringBoot构建一个项目,只需要引入所需框架的依赖,配置就可以交给SpringBoot处理了。
-
@ComponentScan:配置组件扫描的指令提供了类似与context:component-scan标签的作用通过basePackageClasses或者basePackages属性来指定要扫描的包。如果没有指定这些属性,那么将从声明这个注解的类所在的包开始,扫描包及子包。而我们的@SpringBootApplication注解声明的类就是main函数所在的启动类,因此扫描的包是该类所在包及其子包。因此,一般启动类会放在一个比较前的包目录中。
编写测试类
package com.example.demo.cotroller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* 测试类
*/
@RestController
public class TextController {
/**
* 首页
* @return
*/
@RequestMapping("index")
public String index(){
return "holle world";
}
}
启动
测试路径
http://localhost:8080/index
使用Maven创建SpringBoot工程
创建好后,修改pom文件
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>springbootmvc</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- boot工程父依赖 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.5.4</version>
</parent>
<!-- maven配置 -->
<properties>
<java.version>1.8</java.version>
</properties>
<!-- 项目依赖 -->
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
<!-- 项目插件 -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
编写一个启动类
package com.boot;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class SpringMVCApplication {
public static void main(String[] args) {
SpringApplication.run(SpringMVCApplication.class,args);
}
}
测试和启动都和上面一样的我就不重复写了