SpringBoot的HandlerInterceptor中依賴(lài)注入為null問(wèn)題
SpringBoot HandlerInterceptor依賴(lài)注入為null
原因
攔截器加載是在springcontext創(chuàng)建之前完成
解決方案
使用@Bean在攔截器初始化之前讓類(lèi)加載
1.在WebMvcConfigurer的自定義子類(lèi)加載攔截類(lèi),代碼如下:
@Configuration
public class ApIAppConfigurer implements WebMvcConfigurer {
/**
* 注入自定義攔截類(lèi)到spring容器
* @return
*/
@Bean
public ApiInterceptorAdapter getMyInterceptor(){
return new ApiInterceptorAdapter();
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(getMyInterceptor()) //指定攔截器類(lèi)
.addPathPatterns("/api/**"); //指定該類(lèi)攔截的url
}
}
2.使用@Component把攔截類(lèi)交與spring容器管理,代碼如下:
@Component
public class ApiInterceptorAdapter extends HandlerInterceptorAdapter {
@Autowired
private IApiTokenService iApiTokenService;
}
3.完成上述兩步就可以通過(guò)@Autowired 注入service了。
spring依賴(lài)注入對(duì)象為null
前不久幫一個(gè)同事調(diào)試一段代碼,發(fā)現(xiàn)注入對(duì)象為null
被注解的對(duì)象如下
@Component
public class SparkSource{
@Autowired
private SparkConfig sparkConfig ;
@Autowired
private RedisUtils redisUtils;
在調(diào)用SparkSource時(shí)候使用了注入的方式
@Component
public class Owner{
@Autowired
private SparkSource sparkSource;
然后在使用SparkSource 對(duì)象的時(shí)候一直報(bào)null;剛開(kāi)始以為是注入失敗,斷點(diǎn)調(diào)試發(fā)現(xiàn)SparkSource對(duì)象里面的RedisUtils居然也是為null,說(shuō)明要不就是注入不成功,要不就是沒(méi)有進(jìn)行初始化。
修改默認(rèn)構(gòu)造,啟動(dòng)日志發(fā)現(xiàn)申明bean是成功的。那就是在注入的時(shí)候出現(xiàn)了問(wèn)題,然后一直在Owner里面找原因,留意到其實(shí)這個(gè)對(duì)象本身也是被申明成一個(gè)bean組件。
然后跳出Owner,發(fā)現(xiàn)其實(shí)在他最開(kāi)始的調(diào)用竟然是以new Owner()的方式來(lái)獲取對(duì)象:
Owner owner = new Owner();
這時(shí)候終于找到問(wèn)題的所在了。修改為:
@Autowired private Owner owner ;
當(dāng)對(duì)象聲明為bean組件的時(shí)候,它是交給spring容器去管理的,容器會(huì)幫你進(jìn)行初始化;但是如果使用new方法來(lái)調(diào)用對(duì)象時(shí),會(huì)跳過(guò)spring容器生成新的對(duì)象,這時(shí)候就無(wú)法進(jìn)行初始化,所以在調(diào)試的時(shí)候就會(huì)出現(xiàn)SparkSource對(duì)象為null,并且SparkSource對(duì)象里面以注入方式引用的對(duì)象也為null;被申明為bean對(duì)象的組件必須使用注入的方式進(jìn)行調(diào)用。
這是一個(gè)spring依賴(lài)注入新手很容易忽視的一個(gè)問(wèn)題,一般也不會(huì)去重視,希望大家在寫(xiě)代碼的時(shí)候能多加留意。
本文描述可能不夠詳細(xì),大家有空可以去了解一下更多的關(guān)于spring依賴(lài)注入與控制反轉(zhuǎn)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot項(xiàng)目的多文件兼多線(xiàn)程上傳下載
本文主要介紹了SpringBoot項(xiàng)目的多文件兼多線(xiàn)程上傳下載,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
Java StringBuffer與StringBuilder有什么區(qū)別
當(dāng)對(duì)字符串進(jìn)行修改的時(shí)候,需要使用 StringBuffer 和 StringBuilder類(lèi),和String類(lèi)不同的是,StringBuffer和 StringBuilder類(lèi)的對(duì)象能夠被多次的修改,并且不產(chǎn)生新的未使用對(duì)象,本篇我們來(lái)分析分析它們的區(qū)別2023-01-01
Java?遠(yuǎn)程調(diào)用失敗重試的操作方法
這篇文章主要介紹了Java?遠(yuǎn)程調(diào)用失敗重試的操作方法,今天給大家介紹了一下?Spring??的?@Retryable?注解使用,并通過(guò)幾個(gè) demo 來(lái)帶大家編寫(xiě)了自己重試攔截器以及回滾方法,需要的朋友可以參考下2022-09-09
Java實(shí)戰(zhàn)之校園外賣(mài)點(diǎn)餐系統(tǒng)的實(shí)現(xiàn)
這篇文章主要介紹了如何利用Java實(shí)現(xiàn)簡(jiǎn)易的校園外賣(mài)點(diǎn)餐系統(tǒng),文中采用的技術(shù)有:JSP、Spring、SpringMVC、MyBatis 等,感興趣的可以了解一下2022-03-03
Mybatis-plus3.4.3下使用lambdaQuery報(bào)錯(cuò)解決
最近在使用lambdaQuery().eq(CommonUser::getOpenId, openId).one()進(jìn)行查詢(xún)報(bào)錯(cuò),本文主要介紹了Mybatis-plus3.4.3下使用lambdaQuery報(bào)錯(cuò)解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-07-07
RocketMQ?Broker實(shí)現(xiàn)高可用高并發(fā)的消息中轉(zhuǎn)服務(wù)
RocketMQ消息代理(Broker)是一種高可用、高并發(fā)的消息中轉(zhuǎn)服務(wù),能夠接收并存儲(chǔ)生產(chǎn)者發(fā)送的消息,并將消息發(fā)送給消費(fèi)者。它具有多種消息存儲(chǔ)模式和消息傳遞模式,支持水平擴(kuò)展和故障轉(zhuǎn)移等特性,可以為分布式應(yīng)用提供可靠的消息傳遞服務(wù)2023-04-04
JavaWeb實(shí)現(xiàn)Session跨頁(yè)面?zhèn)鬟f數(shù)據(jù)
本文主要介紹了 JavaWeb實(shí)現(xiàn)Session跨頁(yè)面?zhèn)鬟f數(shù)據(jù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
Java8 Optional優(yōu)雅空值判斷的示例代碼
這篇文章主要介紹了Java8 Optional優(yōu)雅空值判斷的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-05-05

