1、創建SpringBoot項目 1.1 使用Spring Initializr 的 Web頁面創建項目 創建網址:https://start.spring.io/ 1.2 使用IDEA創建 省略; 2、第一個hello 2.1 代碼 在 xxxApplication(項目名+Application ...
1、創建SpringBoot項目
1.1 使用Spring Initializr 的 Web頁面創建項目
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圖網址:https://www.bootschool.net/ascii