SpringBoot基礎(chǔ)框架詳解
SpringBoot基礎(chǔ) – 框架介紹
1.SpringBoot介紹
1.1 概述
SpringBoot開發(fā)目的是為了簡化Spring應(yīng)用的創(chuàng)建、運(yùn)行、調(diào)試和部署等。使用Spring Boot可以做到專注于Spring應(yīng)用的開發(fā),而無需過多關(guān)注XML的配置。簡單來說,它提供了一堆依賴打包,并已經(jīng)按照使用習(xí)慣解決了依賴問題。使用Spring Boot可以不用或者只需要很少的Spring配置就可以讓企業(yè)項(xiàng)目快速運(yùn)行起來。
1.2 核心功能
- 獨(dú)立運(yùn)行Spring項(xiàng)目:SpringBoot可以以獨(dú)立的JAR包運(yùn)行。
- 內(nèi)嵌Servlet:SpringBoot可以選擇使用Tomcat、Jetty或者Undertow,無須以war包形式部署項(xiàng)目。
- 簡化配置:Spring提供推薦的基礎(chǔ) POM 文件來簡化Maven 配置。
- 自動(dòng)配置Spring:SpringBoot會根據(jù)項(xiàng)目依賴來自動(dòng)配置Spring 框架,極大地減少項(xiàng)目要使用的配置。
- 提供生產(chǎn)就緒型功能:提供可以直接在生產(chǎn)環(huán)境中使用的功能,如性能指標(biāo)、應(yīng)用信息和應(yīng)用健康檢查。
- 無代碼生成和XML配置:SpringBoot不生成代碼。完全不需要任何xml配置即可實(shí)現(xiàn)Spring的所有配置。
2.框架區(qū)別
2.1 SpringBoot與Spring
SpringBoot Web組件默認(rèn)集成SpringMVC框架,SpringMVC3.0以后支持注解方式使用java代碼啟動(dòng)SpringMVC。
2.2 SpringBoot與SpringCloud
- SpringBoot快速整合第三方框架(Maven依賴關(guān)系###Maven繼承),完全采用注解化,簡化XML配置,最終以java應(yīng)用程序進(jìn)行執(zhí)行。
- SpringCloud一套目前完整的微服務(wù)解決框架,功能非常強(qiáng)大,注冊中心,客戶端調(diào)用工具,服務(wù)治理(負(fù)載均衡,斷路器,分布式配置中心,網(wǎng)管,消息總線等)。
- 關(guān)系:微服務(wù)通訊技術(shù)Http+json(restfull)輕量級,SpringBoot Web組件默認(rèn)集成SpringMVC,SpringCloud依賴于SpringBoot實(shí)現(xiàn)微服務(wù),使用SpringMVC編寫微服務(wù)接口。
3.框架詳解
3.1 簡化項(xiàng)目創(chuàng)建
在使用Spring過程中,需要用戶手動(dòng)在pom中添加項(xiàng)目依賴,而在SpringBoot中starter-web組件就已經(jīng)包含多個(gè)依賴,因此能大幅簡化項(xiàng)目的創(chuàng)建流程。
<!-- .....省略其他依賴 --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.0.7.RELEASE</version> <scope>compile</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.0.7.RELEASE</version> <scope>compile</scope> </dependency>
3.2 簡化配置
SpringBoot更多的是采用 Java Config 的方式,對 Spring 進(jìn)行配置。以下演示如何讓SpringBoot管理一個(gè)類和方法
public class TestService { public String sayHello () { return "Hello Spring Boot!"; } } import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class JavaConfig { @Bean public TestService getTestService() { return new TestService(); } }
@Configuration表示該類是個(gè)配置類,@Bean表示該方法返回一個(gè) Bean。這樣就把TestService作為 Bean 讓 Spring 去管理了,在其他地方,我們?nèi)绻枰褂迷?Bean,和原來一樣,直接使用@Resource注解注入進(jìn)來即可使用,非常方便。
3.3 簡化部署
在使用 Spring 時(shí),項(xiàng)目部署時(shí)需要我們在服務(wù)器上部署 tomcat,然后把項(xiàng)目打成 war 包扔到 tomcat里,在使用 SpringBoot 后,我們不需要在服務(wù)器上去部署 tomcat,因?yàn)?SpringBoot 內(nèi)嵌了 tomcat,我們只需要將項(xiàng)目打成 jar 包,使用 java -jar xxx.jar一鍵式啟動(dòng)項(xiàng)目。
4.SpringBoot常用注解
4.1 @SpringBootApplication
SpringBoot的核心注解,使用在SpringBoot主類上,用于啟動(dòng)SpringBoot各個(gè)組件
4.2 @EnableAutoConfiguration
SpringBoot自動(dòng)配置注解,使用該注解后SpringBoot 就能根據(jù)當(dāng)前類路徑下的包或者類來配置 SpringBean。@EnableAutoConfiguration
實(shí)現(xiàn)的關(guān)鍵在于引入AutoConfigurationImportSelector,核心邏輯為selectImports方法
- 從配置文件META-INF/spring.factories加載所有可能用到的自動(dòng)配置類。
- 去重,并將exclude和excludeName屬性攜帶的類排除。
- 過濾,將滿足條件(@Conditional)的自動(dòng)配置類返回
4.3 @Configuration
定義配置類,指出該類是Bean配置信息來源,一般加在主類上。如果有些第三方庫需要用到xml文件,建議仍然通過@Configuration類作為項(xiàng)目的配置主類——可以使用@ImportResource注解加載xml配置文件。
4.4 @ComponentScan
組件掃描。讓springBoot掃描到Configuration類并把它加入到程序上下文。@ComponentScan注解默認(rèn)就會裝配標(biāo)識了@Controller,@Service,@Repository,@Component注解的類到spring容器中。
4.5 @Repository
標(biāo)注數(shù)據(jù)訪問組件及DAO組件。使用@Repository注解可以確保DAO或repositories提供異常轉(zhuǎn)譯,這個(gè)注解修飾的DAO或者repositories類會被ComponetScan發(fā)現(xiàn)并配置,同時(shí)也不需要為它們提供XML配置項(xiàng)。
4.6 @Service
一般用于修飾service層的組件
4.7 @RestController
用于標(biāo)注控制層組件,表示為控制器Bean,并將函數(shù)的返回值直接寫入HTTP響應(yīng)體中,是REST風(fēng)格控制器。它是@Controller和@ResponseBody的合集。
4.8 @RequestBody
表示該方法的返回值直接寫入HTTP response body中。一般在異步獲取數(shù)據(jù)時(shí)使用,在使用@RequestMapping后,返回值通常解析為跳轉(zhuǎn)路徑,加上@responsebody后返回結(jié)果不會被解析為跳轉(zhuǎn)路徑,而是直接寫入HTTP response body中。比如異步獲取json數(shù)據(jù),加上@responsebody后,會直接返回json數(shù)據(jù)。
4.9 @Component
泛指組件,當(dāng)組件不好歸類的時(shí)候,我們可以使用這個(gè)注解進(jìn)行標(biāo)注。
4.10 @Bean
相當(dāng)于XML中的,放在方法的上面,而不是類,意思是產(chǎn)生一個(gè)bean,并交給spring管理。
4.11 @Autowired
byType方式。把配置好的Bean拿來用,完成屬性、方法的組裝,它可以對類成員變量、方法及構(gòu)造函數(shù)進(jìn)行標(biāo)注,完成自動(dòng)裝配的工作。當(dāng)加上(required=false)時(shí),就算找不到bean也不報(bào)錯(cuò)。
4.12 @RequestMapping
RequestMapping是一個(gè)用于處理請求地址映射的注解。提供路由信息,負(fù)責(zé)URL至Controller中具體函數(shù)映射,可用于類或方法上。注解在類上表示類中的所有響應(yīng)請求的方法都是以該地址作為父路徑。
4.13 @RequestParam
在方法的參數(shù)前面。例:
@RequestParam String a =request.getParameter(“a”)。
4.14 @PathVariable
路徑變量。參數(shù)與大括號里的名字一樣要相同。
RequestMapping("user/get/mac/{macAddress}") public String getByMacAddress(@PathVariable String macAddress){ //do something; }
到此這篇關(guān)于SpringBoot基礎(chǔ)框架詳解的文章就介紹到這了,更多相關(guān)SpringBoot基礎(chǔ)框架內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Maven中optional和scope元素的使用弄明白了嗎
這篇文章主要介紹了Maven中optional和scope元素的使用弄明白了嗎,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無法加載主類的幾種解決方法
本文主要介紹了SpringBoot項(xiàng)目啟動(dòng)錯(cuò)誤:找不到或無法加載主類的幾種解決方法,具有一定的參考價(jià)值,感興趣的可以了解一下2025-03-03intellij idea自動(dòng)生成類注釋和方法注釋配置方法
這篇文章主要介紹了intellij idea自動(dòng)生成類注釋和方法注釋設(shè)置方法,需要的朋友可以參考下2023-01-01SpringBoot配置Redis自定義過期時(shí)間操作
這篇文章主要介紹了SpringBoot配置Redis自定義過期時(shí)間操作,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07JVM參數(shù)NativeMemoryTracking的使用
本文主要介紹了JVM參數(shù)NativeMemoryTracking的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-01-01詳細(xì)總結(jié)各種排序算法(Java實(shí)現(xiàn))
下面小編就為大家?guī)硪黄敿?xì)總結(jié)各種排序算法(Java實(shí)現(xiàn))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09