詳解SpringBoot啟動(dòng)類的掃描注解的用法及沖突原則
背景
SpringBoot 啟動(dòng)類上,配置掃描包路徑有三種方式,最近看到一個(gè)應(yīng)用上三種注解都用上了,代碼如下:
@SpringBootApplication(scanBasePackages ={"a","b"}) @ComponentScan(basePackages = {"a","b","c"}) @MapperScan({"XXX"}) public class XXApplication extends SpringBootServletInitializer }
那么,疑問(wèn)來(lái)了:SpringBoot 中,這三種注解生效優(yōu)先級(jí)如何、第一種和第二種有沒(méi)有區(qū)別呢?本文來(lái)整理下這三個(gè)注解的注意事項(xiàng)。
SpringBootApplication 注解
這是 SpringBoot 的注解,本質(zhì)是三個(gè) Spring 注解的和
- @Configuration
- @EnableAutoConfiguration
- @ComponentScan
它默認(rèn)掃描啟動(dòng)類所在包及其所有子包, 但是不包括第三方的 jar 包的其他目錄 ,通過(guò) scanBasePackages
屬性可以重新設(shè)置掃描包路徑。
注意:如果我們需要掃描依賴 jar 包中的注解,而依賴包的路徑跟不包含在 SpringBoot 啟動(dòng)類路徑中的話,我們就要單獨(dú)使用 @ComponentScan
注解掃描第三方包。同時(shí)必須指定本工程的掃描路徑, 因?yàn)橐坏┯羞@個(gè)注解后,它優(yōu)先,默認(rèn)掃描包就失效了 。
例如這個(gè)工程:
SpringBoot 啟動(dòng)類的工程目錄為 cn.com.a.b
,引用的第三方公共包 xxx.common.jar
的目錄也是 cn.com.a.b
,那么第三方 jar 包中的注解天然能直接被掃描到。其他的 jar 包中,如果有注解,就無(wú)法掃描到了。
ComponentScan注解
這個(gè)是 Spring 框架的注解,它用來(lái)指定組件掃描路徑,如果用這個(gè)注解,它的值必須包含整個(gè)工程中全部需要掃描的路徑。因?yàn)樗鼤?huì)覆蓋 SpringBootApplication
的默認(rèn)掃描路徑,導(dǎo)致其失效。
失效表現(xiàn)有兩種:
第一,如果 ComponentScan
只包括一個(gè)值且就是默認(rèn)啟動(dòng)類目錄, SpringBootApplication
生效, ComponentScan
注解失效,報(bào)錯(cuò):
第二,如果 ComponentScan
指定多個(gè)具體子目錄,此時(shí) SpringBootApplication
會(huì)失效,Spring 只會(huì)掃描 ComponentScan
指定目錄下的注解。如果恰好有目錄外的 Controller 類,很遺憾,這些控制器將無(wú)法訪問(wèn)。
回到開(kāi)頭那段代碼:
@SpringBootApplication(scanBasePackages ={}) @ComponentScan(basePackages = {})
這里指定了 ComponentScan
注解后, scanBasePackages
就失效了。因此,如果 ComponentScan
的 basePackages
值不包括 cn.com.a.b
即啟動(dòng)類所在的包,僅指定了第三方 jar 的目錄,那么 這個(gè)工程下任何的注解都無(wú)法被掃描到 。
MapperScan 注解
這個(gè)是 MyBatis 的注解,會(huì)將指定目錄下所有 DAO 類封裝成 MyBatis 的 BaseMapper
類,然后注入 Spring 容器中, 不需要額外的注解 ,就可以完成注入。
啟示錄
SpringBoot 包掃描路徑,兩個(gè)注解的沖突行為,我反復(fù)驗(yàn)證了好久確定了現(xiàn)象,但是沒(méi)有找到合理的解釋。這篇文章在草稿箱醞釀了快兩周了,一直擱置著。
今天搜到了一篇文章,說(shuō)二者同時(shí)使用時(shí), SpringBootApplication
會(huì)失效,至此 SpringBoot 掃描路徑的疑惑終于消除了。
到此這篇關(guān)于詳解SpringBoot啟動(dòng)類的掃描注解的用法及沖突原則的文章就介紹到這了,更多相關(guān)SpringBoot啟動(dòng)類掃描注解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Jmeter使用接口傳遞數(shù)據(jù)過(guò)程圖解
這篇文章主要介紹了Jmeter使用接口傳遞數(shù)據(jù)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05SpringBoot實(shí)現(xiàn)獲取客戶端IP地理位置
在當(dāng)今互聯(lián)的世界中,了解客戶端的地理位置對(duì)于提供個(gè)性化服務(wù)和增強(qiáng)用戶體驗(yàn)至關(guān)重要,使用本文為大家介紹了SpringBoot獲取客戶端IP地理位置的相關(guān)方法,需要的小伙伴可以參考下2023-11-11將Java項(xiàng)目打包成可執(zhí)行的jar包
這篇文章主要介紹了將Java項(xiàng)目打包成可執(zhí)行的jar包,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06淺談MyBatis3 DynamicSql風(fēng)格語(yǔ)法使用指南
這篇文章主要介紹了淺談MyBatis3 DynamicSql風(fēng)格語(yǔ)法使用指南,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03java實(shí)現(xiàn)遠(yuǎn)程桌面的實(shí)例代碼
下面小編就為大家分享一篇java實(shí)現(xiàn)遠(yuǎn)程桌面的實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01IDEA自動(dòng)生成TestNG的testng.xml的插件方法
這篇文章主要介紹了IDEA自動(dòng)生成TestNG的testng.xml的插件方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04java枚舉使用詳細(xì)介紹及實(shí)現(xiàn)
這篇文章主要介紹了java枚舉使用詳細(xì)介紹及實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2017-06-06Java Spring數(shù)據(jù)單元配置過(guò)程解析
這篇文章主要介紹了Java Spring數(shù)據(jù)單元配置過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12