一、 Spring Boot 入门
1、 Spring Boot 简介
简化Spring应用开发的一个框架;
整个Spring技术栈的一个大整合;
优点
- 快熟创建独立运行的Spring项目以及与主流框架及集成
- 使用嵌入式框架Servlet容器,应用无需打包成war包
- starters自动依赖于版本控制
- 大量的自动配置,简化开发,也可修改默认值
- 无需配置 xml , 无代码生成,开箱即用
- 准生产环境的运行时应用监控
- 与云计算的天然集成
2、 微服务
2014 , martin fowler - 《微服务 | Martin Fowler》 - 中文版
微服务:架构风格(服务微化)
一个应用应该是一组小型服务:可以通过 HTTP
的方式进行互通;
单体应用 ALL IN ONE
微服务:每个功能元素最终都是一个可独立替换和独立升级的软件单元;
环境约束
-jdk1.8:spring Boot 1.7及以上:java -version; “1.8.0_101”
-maven3.x:maven 3.3以上版本;mvn -v
-IntelliJIDEA2017(我用sping 官方推荐使用的 Eclipse - sts)
-SpringBoot 1.5.9.REALEASE
统一环境:
MAVEN设置:
给MAVEN添加profiles标签(设置java版本)
4、 Spring Boot HelloWorld
一个功能:
浏览器发送hello请求,服务器接收请求并处理,响应Hello World字符串;
1. 创建一个maven工程(jar)
2. 导入Spring Boot 依赖 https://docs.spring.io/spring-boot/docs/2.2.2.RELEASE/reference/html/getting-started.html#getting-started
3. 编写一个主程序
package com.edut;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/** * @SpringBootApplication 来标注一个主程序类,说明是一个 spring boot应用 */
@SpringBootApplication
public class HelloWorldMainApplication {
/** * Spring 应用启动起来 */
public static void main(String[] args) {
SpringApplication.run(HelloWorldMainApplication.class, args) ;
}
}
4. 编写相关的 Controller、Servlet
package com.edut.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
@ResponseBody//让返回值,作为body内容写出去
@RequestMapping("/hello")
public String hello() {
return "Hello Spring ~~" ;
}
}
5. 运行主程序测试
6. 简化部署
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
将这个应用打成jar包,直接使用java -jar的命令进行执行!
5、 Hello World 探究
1. POM文件
父项目
以前作为依赖管理
------------------------
pom.xml中
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.2.RELEASE</version>
</parent>
------------------------
父项目中:来真正管理 Spring Boot 应用里面的所有依赖版本
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.2.2.RELEASE</version>
<relativePath>../../spring-boot-dependencies</relativePath>
</parent>
Spring Boot 的版本仲裁中心
以后我们导入依赖,默认是不需要写版本;(没有在 dependency里面管理的依赖自然需要声明版本号)
2. 导入的依赖
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
Spring Boot 场景启动器:帮我们导入了 web 模块正常运行所依赖的组件:
- spring-boot
- starter-web
Spring Boot 将所有的功能场景都抽取出来,做成一个个的 starters(启动器),只需要在项目里面引入这些 starter 相关场景的所有依赖都会导入进来。
要用什么功能就导入什么场景的启动器。
https://docs.spring.io/spring-boot/docs/2.2.0.RELEASE/reference/htmlsingle/#boot-documentation
2、 主程序类,主入口类
package com.edut;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/** * @SpringBootApplication 来标注一个主程序类,说明是一个 spring boot应用 */
@SpringBootApplication
public class HelloWorldMainApplication {
/** * Spring 应用启动起来 */
public static void main(String[] args) {
SpringApplication.run(HelloWorldMainApplication.class, args) ;
}
}
@SpringBootApplication Spring Boot 应用标注在某个类上说明这个类似 SpringBoot 的主配置类。
SpringBoot就应用在这个类的main 方法来启动这个SpringBoot
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(excludeFilters = { @Filter(type = FilterType.CUSTOM, classes = TypeExcludeFilter.class),
@Filter(type = FilterType.CUSTOM, classes = AutoConfigurationExcludeFilter.class) })
public @interface SpringBootApplication {
<mark>@SpringBootConfiguration</mark> Spring Boot 的配置类
标注在某个类上,表示这是一个 Spring Boot的配置类:@Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @Component public @interface Configuration {
<mark>@Configuration</mark> 配置类上来标注这个注解:
配置类 。。。。。配置文件;配置类也是容器中的一个组件:@Component
<mark>@EnableAutoConfiguration</mark>:开启自动配置功能;
以前我们饿需要配置的东西,Spring Boot 帮我们配置;
<mark>@EnableAutoConfiguration</mark> 告诉 SpringBoot开启自动配置功能。
这样自动配置才能生效
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@AutoConfigurationPackage
@Import(AutoConfigurationImportSelector.class)
public @interface EnableAutoConfiguration {
<mark>@AutoConfigurationPackage</mark>: 自动配置包
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@Import(AutoConfigurationPackages.Registrar.class)
public @interface AutoConfigurationPackage {
<mark>@import(AutoConfigurationPackages.Registrar.class)</mark>:
Spring 的底层注解 @import ,给容器中导入一个组件;
导入组件AutoConfigurationPackage.Registrar.class
;
<mark>将 主配置类(@SpringBootApplication 标注的类)的所在的包以及下面所有子包的所有组件扫描到 Spring 容器中</mark>。
<mark>@Import(AutoConfigurationImportSelector.class)</mark>
给容器中导入组件
AutoConfigurationImportSelector:导入那些组件的选择器
将所有需要导入的组件以全类名的方式返回:这些组件就会被添加到容器中。
会给容器中导入非常多的自动配置类(xxxAutoConfiguration):就是给容器中导入这些场景需要的所有组件,并配置好这些组件:
有了自动配置类,免去了我们手动编写配置注入功能组件等的工作
SpringFactoriesLoader.loadFactoryNames(EnableAutoConfiguration.class) , classLoarder
<mark>Spring Boot 在启动的时候,从类路径下的 META-INF/spring.factories 中获取 EnableAutoConfiguration 指定的值 ,
将这些值作为自动配置类导入到容器中,自动配置类就生效,帮我们进行自动配置工作</mark>。
以前我们需要自己配置的东西,自动配置类都帮我们做了
J2EE的整体整合解决方案和自动配置都在
spring-boot-autoconfigure-2.2.2.RELEASE-sources.jar
有兴趣,看《spring注解版》 - b栈
6、使用Spring Initializer快速创建SpringBoot项目
IDE都支持使用Spring的项目创建向导快速创建一个SpringBoot项目;
选择我们需要的模块;
向导会联网创建Spring Boot项目;
默认生成的Spring Boot项目;
- 主程序已经生成好了,我们只需要我们自己的逻辑
- resources 文件中目录结构
- static:保存所有的静态资源:js css images;
- templates:保存所有的末班页面;
(Spring Boot默认jar包使用嵌入式的Tomcat,默认不支持JSP页面);可以使用模板引擎(freemarker、thymeleaf); - application.properties:Spring Boot 应用的配置文件;