WebSocket無法注入屬性的問題及解決方案
踩坑一:
原因:
是因?yàn)镾pring對(duì)象的創(chuàng)建都是以單例模式創(chuàng)建的,在啟動(dòng)時(shí)只創(chuàng)建一次WebSocket。而WebSocketServer在每個(gè)連接請(qǐng)求到來時(shí),都會(huì)new一個(gè)對(duì)象。所以當(dāng)你啟動(dòng)項(xiàng)目時(shí),你想要注入的對(duì)象已經(jīng)注入進(jìn)去,但是當(dāng)用戶連接是,新創(chuàng)建的websocket對(duì)象沒有你要注入的對(duì)象,所以會(huì)報(bào)NullPointerException
解決:
通過static關(guān)鍵字讓webSocketService屬于WebSocketServer類
private static WebSocketService webSocketService; //通過static關(guān)鍵字讓webSocketService屬于WebSocketServer類 @Autowired//注入到WebSocketServer類的webSocketService屬性里 public void setKefuService(WebSocketService webSocketService){ WebSocketServer.webSocketService= webSocketService; }
踩坑二:
使用@ServerEndpoint
聲明的websocket服務(wù)器中自動(dòng)注入
- 錯(cuò)誤方法,這樣無法從容器中獲取
@ServerEndpoint(value = "/chat/{username}") @Service public class WebSocketServer { @Resource // @Autowired private RabbitTemplate rabbitTemplate; //null }
- 解決:使用上下文獲取
@ServerEndpoint(value = "/chat/{username}") @Service public class WebSocketServer { /* * 提供一個(gè)spring context上下文(解決方案) */ private static ApplicationContext context; public static void setApplicationContext(ApplicationContext applicationContext) { WebSocketServer.context = applicationContext; } }
- 在啟動(dòng)類中傳入上下文
@SpringBootApplication public class TalkApplication { public static void main(String[] args) { //解決springboot和websocket之間使用@autowired注入為空問題 ConfigurableApplicationContext applicationContext = SpringApplication.run(TalkApplication.class, args); //這里將Spring Application注入到websocket類中定義的Application中。 WebSocketServer.setApplicationContext(applicationContext); } }
- 在使用的地方通過上下文去獲取服務(wù)
context.getBean()
;
public void sendSimpleQueue(String message) { String queueName = "talk"; // 在使用的地方通過上下文去獲取服務(wù)context.getBean(); RabbitTemplate rabbitTemplate = context.getBean(RabbitTemplate.class); rabbitTemplate.convertAndSend(queueName, message); }
到此這篇關(guān)于WebSocket無法注入屬性的文章就介紹到這了,更多相關(guān)WebSocket無法注入屬性內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java如何使用Agent和ASM在字節(jié)碼層面實(shí)現(xiàn)方法攔截
Agent是一種運(yùn)行在 Java 虛擬機(jī) (JVM) 上的特殊程序,ASM是一個(gè)輕量級(jí)的 Java 字節(jié)碼編輯和分析框架,本文為大家介紹了如何利用他們?cè)谧止?jié)碼層面實(shí)現(xiàn)方法攔截,感興趣的可以了解一下2023-05-05Spring通過<import>標(biāo)簽導(dǎo)入外部配置文件
之前文章里我們講到Spring加載Xml配置文件的細(xì)節(jié),那么加載完了我們肯定要解析這個(gè)配置文件中定義的元素。這篇我們首先來分析下Spring是如何通過標(biāo)簽導(dǎo)入外部配置文件的。2021-06-06SpringBoot統(tǒng)一數(shù)據(jù)返回的方法實(shí)現(xiàn)
在前后端交互過程中,為了便于數(shù)據(jù)處理,后端數(shù)據(jù)需要進(jìn)行統(tǒng)一封裝返回給前端,這種做法不僅方便前后端溝通,降低了溝通成本,還有助于項(xiàng)目的統(tǒng)一維護(hù)和后端技術(shù)部門的規(guī)范制定,本文就來介紹一下2024-10-10Java基于Socket實(shí)現(xiàn)簡單的多線程回顯服務(wù)器功能示例
這篇文章主要介紹了Java基于Socket實(shí)現(xiàn)簡單的多線程回顯服務(wù)器功能,結(jié)合實(shí)例形式分析了java使用socket進(jìn)行多線程數(shù)據(jù)傳輸?shù)南嚓P(guān)操作技巧,需要的朋友可以參考下2017-08-08淺談java中replace()和replaceAll()的區(qū)別
這篇文章主要介紹了java中replace()和replaceAll()的區(qū)別,兩者都是常用的替換字符的方法,感興趣的小伙伴們可以參考一下2015-11-11springboot2.2.2集成dubbo的實(shí)現(xiàn)方法
這篇文章主要介紹了springboot2.2.2集成dubbo的實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01Java之?dāng)?shù)組在指定位置插入元素實(shí)現(xiàn)
本文主要介紹了Java之?dāng)?shù)組在指定位置插入元素實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01Java 基于UDP協(xié)議實(shí)現(xiàn)消息發(fā)送
這篇文章主要介紹了Java 基于UDP協(xié)議實(shí)現(xiàn)消息發(fā)送,幫助大家更好的理解和學(xué)習(xí)Java網(wǎng)絡(luò)編程,感興趣的朋友可以了解下2020-11-11