上週在定位問題時,發現Spring容器實例化Bean的時候拋出異常,爲了查看更詳細的信息,決定修改spring-context-4.0.2.RELEASE.jar中的CommonAnnotationBeanPostProcessor類的代碼,在裏面打印出更詳細的信息,以便咱們分析和定位問題,下面咱們一步一步經過實戰來修改和編譯spring-context的源碼;java
下載源碼的第一步,是找個用到了spring-context-4.0.2.RELEASE.jar的java工程,若是讀者您手裏沒有現成的工程,能夠在個人git上下載,地址:https://github.com/zq2599/blog_demosgit
下載後能夠發現裏面有不少工程,本次實戰用的工程是springmybatisexceptiondemo,以下圖紅框所示:程序員
用命令行進入pom.xml所在的目錄下,執行命令mvn dependency:sources,便可下載全部依賴庫的源碼包,以下圖:github
此時進入maven的本地倉庫,找到spring-context的目錄,在裏面就能看到源碼的jar包,以下圖:web
maven的本地倉庫,通常在用戶目錄的.m2文件夾下;spring
在maven的本地倉庫中,找到spring-context的目錄後,將裏面的spring-context-4.0.2.RELEASE.pom,spring-context-4.0.2.RELEASE-sources.jar,spring-context-4.0.2.RELEASE.jar這三個文件都複製到一個新建的文件夾中,而後將spring-context-4.0.2.RELEASE-sources.jar和spring-context-4.0.2.RELEASE.jar都解壓;緩存
新建一個maven工程,pom文件的內容和spring-context-4.0.2.RELEASE.pom的如出一轍,以下圖:tomcat
進入剛纔解壓的spring-context-4.0.2.RELEASE-sources.jar的文件夾,把裏面的org文件夾整個都複製到新建的maven工程的java文件夾下,以下圖所示:mybatis
只複製java文件是不夠的,還要複製META-INF和xsd文件,這些東西都不在spring-context-4.0.2.RELEASE-sources.jar包中,還記得剛剛咱們把spring-context-4.0.2.RELEASE.jar文件也解壓了麼?META-INF和xsd文件在這個解壓的文件夾中能夠找到;maven
先是META-INF,在spring-context-4.0.2.RELEASE.jar的解壓目錄中,把META-INF文件夾複製到新建的maven工程的resources文件夾下,以下圖所示:
接下來是xsd文件,在spring-context-4.0.2.RELEASE.jar的解壓目錄中,進入org/springframework/cache/config子目錄,裏面不以class爲後綴的文件有四個,把這四個文件所有複製到maven工程源碼的org/springframework/cache/config目錄下,以下圖:
如下幾個目錄下也有xsd文件,請像上面的方法同樣,將裏面的xsd和gif都複製到maven工程中對應的目錄下:
org/springframework/context/configorg/springframework/ejb/configorg/springframework/scheduling/configorg/springframework/scripting/config
在上面所建的maven工程的pom.xml文件所在目錄下,執行命令mvn clean package -U -Dmaven.test.skip=true,執行成功後,在target目錄下就能看到最新構建的jar包了,以下圖:
至此,咱們實踐了構建spring-context的jar包的過程,根據實際須要,咱們能夠先修改了源碼再構建,例以下圖是我修改的CommonAnnotationBeanPostProcessor類的源碼,很簡單,加了一些輸出,好比打印當前緩存的key,以及代碼的調用棧狀況:
改完代碼後從新構建,生成新的spring-context-4.0.2.RELEASE.jar文件,個人web應用以前已經部署在了tomcat下,如今打開這個應用的lib目錄,用這個jar替換原有的文件,再重啓tomcat,在控制檯能夠看到打印出了比之前更多的異常堆棧內容,便於咱們定位問題: