1、創建SpringBoot專案
1.1 使用Spring Initializr 的 Web頁面創建專案
創建網址:https://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 = "https://www.cnblogs.com/xiaoqigui/p/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圖網址:https://www.bootschool.net/ascii
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/512975.html
標籤:Java
上一篇:詳解MongoDB索引優化
