spring注解在自定義jar包中無法被掃描的解決方案
spring注解在自定義jar包中無法被掃描
前兩天,一朋友在開發(fā)的時(shí)候遇到了一個(gè)問題向我求助, service服務(wù)為第三方提供的服務(wù)里面有spring注解并將service 打成jar包中,使用maven引入。
使用new可以創(chuàng)建,但是使用autowire無法注入提示信息如下圖
報(bào)錯(cuò)信息
這類問題在開發(fā)中一直是我們最不愿意看到的,乍一看,感覺挺對(duì),還挺有道理。但是就是更想要的結(jié)果對(duì)不上。
我當(dāng)時(shí)給出的判斷autowire的類重名導(dǎo)致注入失敗,建議用配合使用qualifier或者 使用resource 但是發(fā)現(xiàn)不是這個(gè)錯(cuò)誤。
于是我為了還原錯(cuò)誤問題花了兩個(gè)小時(shí)終于找到了問題出現(xiàn)的原因,以及解決辦法。
首先出現(xiàn) spring注解在jar包中無法被掃描問題 的出現(xiàn)是 使用eclipse 導(dǎo)出jar包時(shí) 選擇Add directory entries
打jar包時(shí)應(yīng)選擇add directory entries
原因我來解釋一下
首先我最先找到解決辦法是 當(dāng)我們使用 @configuration 加上bean時(shí)可以正常注入 說明包已經(jīng)引入且可以加載到虛擬機(jī)中
使用配置文件注解加入jar包對(duì)象bean
而使用@autowire無法實(shí)現(xiàn)注入說明在 遍歷對(duì)應(yīng)類時(shí)在對(duì)應(yīng)的路徑下無法找到對(duì)應(yīng)的類
因?yàn)槿绻贿x擇Add directory entries 這種默認(rèn)方式生成的jar包中,只含有class文件,而并沒有我們所知的文件夾目錄結(jié)構(gòu)??赡芪覀兇蠖鄶?shù)人認(rèn)為com.neusoft.service.HelloService類,HelloService類文件就應(yīng)該在service文件夾下的文件夾里,這其實(shí)是錯(cuò)誤的看法
com.neusoft.service真正的含義是package包域名,跟文件夾目錄層次結(jié)構(gòu)是兩回事,我們只是習(xí)慣上用文件夾目錄來展示package而已。但package卻不一定非要用過文件夾目錄來展示。
我們可以用下面這段代碼來進(jìn)一步說明這個(gè)問題
將service打成jar包 不選擇Add directory entries
并使用maven命令將 jar包放入本地庫中
mvn install:install-file -Dfile=F:\temp\add\aaa.jar -DgroupId=aaa -DartifactId=noaaa-jar -Dversion=1.0 -Dpackaging=jar
no add diretory entries jar
使用java遍歷
@Test public void test() { // 項(xiàng)目中jar包所在物理路徑 String jarName = "E:\\maven-repository\\aaa\\noaaa-jar\\1.0\\noaaa-jar-1.0.jar"; JarFile jarFile; try { jarFile = new JarFile(jarName); Enumeration<JarEntry> entrys = jarFile.entries(); while (entrys.hasMoreElements()) { JarEntry jarEntry = entrys.nextElement(); System.out.println(jarEntry.getName()); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
遍歷結(jié)果
將service打成jar包 選擇Add directory entries 添加到maven本地倉儲(chǔ)中
命令:
mvn install:install-file
- -DgroupId=包名
- -DartifactId=項(xiàng)目名
- -Dversion=版本號(hào)
- -Dpackaging=jar
- -Dfile=jar文件所在路徑(我這里使用的是絕對(duì)路徑)
mvn install:install-file -Dfile=F:\temp\add\aaa.jar -DgroupId=aaa -DartifactId=aaa-jar -Dversion=1.0 -Dpackaging=jar
add diretory entries jar
使用java遍歷
@Test public void test() { // 項(xiàng)目中jar包所在物理路徑 String jarName = "E:\\maven-repository\\aaa\\aaa-jar\\1.0\\aaa-jar-1.0.jar"; JarFile jarFile; try { jarFile = new JarFile(jarName); Enumeration<JarEntry> entrys = jarFile.entries(); while (entrys.hasMoreElements()) { JarEntry jarEntry = entrys.nextElement(); System.out.println(jarEntry.getName()); } } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
遍歷結(jié)果
META-INF/MANIFEST.MF
com/
com/neusoft/
com/neusoft/service/
com/neusoft/service/HelloService.class
發(fā)現(xiàn)加上Add directory entries 有目錄 而不加只有對(duì)應(yīng)class類。 這也就解釋了為什么無法加載spring的注解。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java大數(shù)據(jù)處理的核心技術(shù)MapReduce框架
MapReduce是一種分布式計(jì)算框架,適用于大規(guī)模的數(shù)據(jù)處理。它將大數(shù)據(jù)分成多個(gè)小數(shù)據(jù)塊,通過Map和Reduce兩個(gè)階段對(duì)數(shù)據(jù)進(jìn)行處理和分析。MapReduce框架具有可靠、高效、可擴(kuò)展等特點(diǎn),已經(jīng)成為大數(shù)據(jù)處理的核心技術(shù)2023-05-05SpringBoot實(shí)現(xiàn)kafka多源配置的示例代碼
實(shí)際開發(fā)中,不同的topic可能來自不同的集群,所以就需要配置不同的kafka數(shù)據(jù)源,基于springboot自動(dòng)配置的思想,最終通過配置文件的配置,自動(dòng)生成生產(chǎn)者及消費(fèi)者的配置,本文介紹了SpringBoot實(shí)現(xiàn)kafka多源配置,需要的朋友可以參考下2024-06-06springMVC中@RequestParam和@RequestPart的區(qū)別
本文主要介紹了springMVC中@RequestParam和@RequestPart的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06Spring里的Async注解實(shí)現(xiàn)異步操作的方法步驟
這篇文章主要介紹了Spring里的Async注解實(shí)現(xiàn)異步操作的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Spring AOP有多少個(gè)通知以及它們的執(zhí)行順序介紹
這篇文章主要介紹了Spring AOP有多少個(gè)通知以及它們的執(zhí)行順序,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11