[問題] springMVC取得所有mapping URL

看板java作者 (老子我最神)時間9年前 (2014/08/12 17:44), 9年前編輯推噓4(408)
留言12則, 3人參與, 最新討論串1/1
大家好 目前在使用 spring MVC, 想做一個功能,但是遇到一些奇妙的問題,雖然最後有解 但仍覺得怪怪的 問題描述有點長,所以我盡量長話短說。 要做的功能是,能夠知道所有 requestMapping 的 URL !! 大致上就是有一個頁面可以去 觀看哪一個 URL 會對應到 哪個 controller 的哪一個 method 查到的解答如下 http://ppt.cc/LzT4 http://ppt.cc/DQig 問題來了,當我仿照產生一個 controller,啟動時卻出現錯誤 錯誤簡單訊息如下 No qualifying bean of type [org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping] found for dependency: expected at least 1 bean which qualifies as autowire candidate for this dependency. 我對於訊息的理解是,從spring的context找不到RequestMappingHandlerMapping 這個 type 於是我又寫了一個頁面去檢查目前spring context所有的 bean 程式碼大致如下 https://gist.github.com/frank780117/e65f2b986adc3119a838 所查出來的結果頁面圖 http://i.imgur.com/PzHuH3v.png
的確是有 RequestMappingHandlerMapping 這一個 bean... class type 也的確是 RequestMappingHandlerMapping.class 比較值得注意的是bean 名稱後面有加上 #0 查了一下是說如果 同一個 bean type有多個的話,就會在後面編號 #0 , #1 這樣 在其他重複的bean我的確有看到 #0, #1 不過 RequestMappingHandlerMapping 只有 #0 ....? 找不到其他的 RequestMappingHandlerMapping#1 之類的 可能是我的程式碼 @Autowire List<ApplicationContext> appContext; 並不是全部的ApplicationContext ? 回到最原始的問題,為什麼用 @Autowire RequestMappingHandlerMapping 會取不到 ? 我從 context 的卻找得到這個 bean, 如果 RequestMappingHandlerMapping 是多個的話 我的 @Autowire List<> 也會失敗... 最後功能我是做出來了,不過是從 appContext 自己抓出 RequestMappingHandlerMapping 來做處理 結果圖如下 http://i.imgur.com/vAWuAeV.png
不過我還是非常困擾 為什麼 @Autowire 會唯獨取不到 RequestMappingHandlerMapping 我取其他的 dependcy 就很正常... 不知道是哪一個觀念搞錯了... 另外我很確定 @Autowire List<ApplicationContext> appContext; 並不會得到全部的 Context,至於為什麼我也不曉得 最後其實網路上也有查到相同問題 http://ppt.cc/8uxd 二樓回答,三樓就解了,不過英文太差不瞭解二樓再說什麼... 感謝大家幫忙了 -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 61.218.64.133 ※ 文章網址: http://www.ptt.cc/bbs/java/M.1407836692.A.FEF.html ※ 編輯: cyclone350 (61.218.64.133), 08/12/2014 17:52:07 ※ 編輯: cyclone350 (61.218.64.133), 08/12/2014 17:54:34 ※ 編輯: cyclone350 (61.218.64.133), 08/12/2014 17:55:41

08/12 18:26, , 1F
有機會看到servlet-context.xml跟root-context.xml嗎?
08/12 18:26, 1F

08/12 18:30, , 2F
大概是RequestMappingHandlerMapping是在servlet-context
08/12 18:30, 2F

08/12 18:31, , 3F
才生出來的,但是你的root-context scan的時候就嘗試建立
08/12 18:31, 3F

08/12 18:31, , 4F
你的controller所以找不到?
08/12 18:31, 4F

08/12 21:04, , 5F
你可以把log level設為info,看看spring在啟動時的順序
08/12 21:04, 5F

08/12 21:04, , 6F
不過我一直以為ApplicationContext只有一個耶...
08/12 21:04, 6F

08/12 21:12, , 7F
然後需要你的設定檔,不然也只是在這裡瞎猜而已
08/12 21:12, 7F
感謝提點,因為電腦放在遙遠的彼方,隔天才能提供設定檔 不過我可以描述設定檔是如何設定的 首先如 phstudy 大說的,我的context有兩個, 分別為 servlet-context 跟 root-context servlet-context 主要為 mvc 的設定如 <mvc:annotation-driven /> 或 <mvc:view-controller value="/css" /> 其中對 controller 取得是用 <bean:component-scan="base-package"> 另外 root-context 包含其他所有設定如 dao, service, 連接資料庫等等 取得 bean 是用 <bean:component-scan="base-package"> 兩個 context 用的 component-scan 是同一個 package (都用根package,因為spring會遞迴搜尋並創建bean) p大跟s大講法我有點頭緒了 我一直以為context是沒有順序性的... 我在使用 <import> 之類的設定也沒考慮到順序 以為他分成兩個context只是分好玩的 XD 另外一問 我使用 @Autowire List<ApplicationContext> 得到的只有一部分的 context,並非全部 想請問這樣的取法有甚麼問題嗎? 因為跟網路教學的方式並不一樣 google到的方法:http://ppt.cc/bpCa 最後提一下 今天發問前有試過刪除 root-context或servlet-context 的 component-scan 因為有查到說 component-scan兩次,會產生兩次bean??? 不過我從 applicationContext 裡面檢查卻只有產生一個 然後修改結果錯誤仍一樣,不過也可能是我漏掉了甚麼 明天有碰電腦再試試看 ※ 編輯: cyclone350 (123.193.192.133), 08/12/2014 22:12:01

08/12 22:54, , 8F
這樣的話就是第一次scan時要exclude @Controller
08/12 22:54, 8F

08/12 22:55, , 9F
第二次再針對base-package=你的controller package
08/12 22:55, 9F

08/12 23:30, , 10F
或是include @Controller
08/12 23:30, 10F

08/12 23:31, , 11F
印象中spring好像是先找bean,才做url mapping
08/12 23:31, 11F

08/12 23:35, , 12F
所以autowired的當下才沒有東西,但啟動後卻在context有
08/12 23:35, 12F
已經解了 的確是 root-context 跟 servlet-context 順序問題 我在 root-context scan exclude @Controller servlet-context scan include @Controller 啟動時就找得到了 感謝大家幫忙 ※ 編輯: cyclone350 (61.218.64.133), 08/13/2014 09:39:19
文章代碼(AID): #1JwU8K_l (java)