SpringBoot(一) – SpringBoot 初識

1、創建SpringBoot項目

1.1 使用Spring Initializr 的 Web頁面創建項目

創建網址://start.spring.io/

1.2 使用IDEA創建

省略;

2、第一個hello

2.1 程式碼

在 xxxApplication(項目名+Application 自動生成) 的啟動類的同級下創建一個controller包,並創建一個控制類

@Controller
public class SpringBootPrimerController {

    /**
     * @author : huayu
     * @date   : 10/10/2022
     * @param  : [msg]
     * @return : java.lang.String
     * @description : 接收前端請求helloSbt,返迴響應字元串
     */
    @RequestMapping("/helloSbt")
	@ResponseBody
    public String hello(@RequestParam(value = "msg") String msg){

        return String.format("Hello %s",msg);

    }

}

application.properties 指定服務埠

# 服務埠
server.port=8080 # 默認時8080

2.2 測試

2.3 新增的註解

@RestController //組合註解,相當於 @Controller +  @ResponseBody

@GetMapping("/helloSbt")//相當於  @RequestMapping(  method = {RequestMethod.GET} )

3、打 jar 包運行

3.1 打包

3.1.1 pom.xml

<!--  指定打包方式,默認方式是jar,還可以是war  -->
<packaging>jar</packaging>

3.1.2 點擊 maven 的 package

3.2 運行jar 包

cmd 到 項目jar包的目錄下

java -jar 項目的 jar包

運行結果

3.3 jar 包運行時 指定 參數

3.3.1 java -jar 項目jar包名 –key=value

3.3.2 java -jar -Dkey=value 項目jar包名

4、啟動器

<!-- starter 啟動器:SpringBoot 框架將各個場景單獨抽離出來,做成一個個啟動器 -->
<!-- 一旦項目中添加了對應的啟動器,自動將對應啟動器中多有的依賴導入到項目中,直接進行添加配置開發即可,無需手動添加依賴 -->
<!-- 實際開發中,使用什麼功能,就直接添加對應的啟動器 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

5、版本控制器 版本仲裁中心:spring-boot-dependencies

5.1 版本控制器

<!-- 為什麼SpringBoot 項目添加依賴有的不需要指定版本(比如fastjson,添加必須指定版本號) -->
<!-- 原因:SpringBoot 框架提供了一個版本控制器(又叫:版本仲裁中心:spring-boot-dependencies) 定義了Springboot的依賴版本 -->
<!-- 好處:開發人員添加依賴不需要知道版本號,且不需要自己單獨維護項目中的各個版本依賴,有防止版本之間的衝突 -->

5.2 找到版本控制器

1、點擊 pom.xml中的啟動器依賴

2.點擊 spring-boot-starter-web 中的依賴 spring-boot-starters

3.點擊 spring-boot-starters 中的依賴 spring-boot-parent

4.點擊 spring-boot-parent 中的依賴 spring-boot-dependencies

5、在 spring-boot-dependencies 中可以看到 springboot對一些依賴的版本進行了版本控制,和衝突處理

6、SpringBoot應用的maven 插件

<!--
     SpringBoot應用的maven 插件,可以將當前SpringBoot 項目直接打包成一個可以執行的jar包,區別與普通jar包(裡面沒有源碼),不能被依賴(比如fastjson依賴jar等)
      即:可以直接通過java -jar 項目指定jar包 命令快速啟動項目
-->
<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
</plugin>

7、SpringBootApplication 註解詳情

此註解,就是SpringBoot應用的核心啟動類;

7.1 @SpringBootConfiguration 註解

標註的類就是SpringBoot的核心配置類,是SpringBoot的專屬註解,實際上跟 @Configuration 註解一致(等同於以前的核心配置文件),在SpringBoot應用啟動時,會自動載入;

@SpringBootConfiguration 實際上跟 @Configuration 註解一致;

7.2 @EnableAutoConfiguration 註解

開啟自動配置註解,以前都是手動創建xml核心配置文件,文件中增加核心配置,現在都交給SpringBoot框架自動配置;

7.2.1 子註解 1 @AutoConfigurationPackage 子註解

  • 開啟自動配置包,實際上就是開啟spring的自動掃描功能;

7.2.1.1 子註解 1 的子註解 @Import(AutoConfigurationPackages.Registrar.class)

@Import(AutoConfigurationPackages.Registrar.class)將springBoot核心啟動類所在的父包及子包中所有的組件,自動添加到容器中

  • 找到 springBoot核心啟動類所在的父包 載入的位置
1、點擊進入 @Import(AutoConfigurationPackages.Registrar.class)

2、點擊 Evalute Expression

3、執行Evalute

可以看出是將springBoot核心啟動類所在的父包及子包中所有的組件,自動添加到容器中

7.2.2 子註解 2 @Import({EnableAutoConfigurationImportSelector.class})

  • 開啟自動配置將springboot框架下MET-INF/spring/spring.factories資源文件中,屬性值 org.springframework.boot.autoconfigure.EnableAutoConfiguration 指定的96個自動配置類,導入到容器中,實現自動配置,省去開發人員手動添加組件到容器中,減少開發的工作量,重心都放在核心業務開發中,不是配置上;

  • 96個自動配置類
1、進入 @Import(EnableAutoConfigurationImportSelector.class)

2、再進入 AutoConfigurationImportSelector

3、跳到 getCandidateConfigurations 方法

可以看到96個configuration 應該在 META-INF/spring.factories中

4、我找到 META-INF/spring.factories

5、在 spring.factories 找到 96個 configuration

7.2.3 子註解 3 @ComponentScan 註解

  • 指定組件掃描,相當於spring核心配置xml文件中<context:component-scan></context:component-scan> 作用;
  • 可以指定一個自定義的包路徑(或者多個),執行組件掃描;
  • 注意:如果核心啟動類上,增加此註解,會導致默認的自動配置包失敗以指定的為準,實際應用時,要避免此種情況出現;

8、banner

在 resources 下 創建文件 banner.txt ,網上複製圖案;

banner圖網址://www.bootschool.net/ascii