修改和編譯spring源碼,構建jar(spring-context-4.0.2.RELEASE)

上週在定位問題時,發現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

解壓jar包,準備材料

在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

構建jar包

在上面所建的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,在控制檯能夠看到打印出了比之前更多的異常堆棧內容,便於咱們定位問題:

這裏寫圖片描述

歡迎關注個人公衆號:程序員欣宸

相關文章
相關標籤/搜索