国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

一次tomcat源碼啟動控制臺中文亂碼的調(diào)試過程記錄

瀏覽:237日期:2023-03-19 16:50:55

發(fā)現(xiàn)問題

今天準(zhǔn)備學(xué)習(xí)下tomcat源碼,于是從官網(wǎng)下載了tomcat的源碼,導(dǎo)入到IDEA中,使用maven工具build完項(xiàng)目之后,啟動項(xiàng)目,控制臺打印了tomcat日志,但是中文都是亂碼。

一開始我懷疑是IDEA的問題,于是在網(wǎng)上找了各種解決辦法嘗試。大致有這幾種:

1、修改run/debug configurations,添加VM options參數(shù):-Dfile.encoding=utf-8;

2、修改run/debug configurations,添加Enviroment variables參數(shù):JAVA_TOOL_OPTIONS:-Dfile.encoding=utf-8和JAVA_OPTS:-Dfile.encoding=utf-8;

3、修改IDEA配置file encodings的3處編碼為UTF-8;

4、修改IDEA的Custom VM options,添加-Dfile.encoding=utf-8;

5、修改IDEA的安裝目錄bin下的idea.exe.vmoptions和idea64.exe.vmoptions文件,添加-Dfile.encoding=utf-8;

6、修改項(xiàng)目下的.idea文件夾下的encodings.xml文件,不是UTF-8的改為UTF-8;

7、修改tomcat的配置文件logging.properties,將里面的UTF-8改為GBK;

8、修改完刪除target文件夾重新編譯;

9、修改完重啟IDEA。

嘗試完所有方法后,控制臺日志亂碼問題并沒有解決,如圖:

仔細(xì)觀察后,發(fā)現(xiàn)日志左邊的日志等級”信息”和”嚴(yán)重”之類的中文亂碼解決了,但是日志中還有亂碼。

感覺應(yīng)該是代碼的問題,于是決定debugger代碼,先從日志的第一行開始。

17-Feb-2020 10:10:08.585 信息 [main] org.apache.catalina.startup.VersionLoggerListener.log Server.æœåŠ¡å™¨ç‰ˆæœ¬: Apache Tomcat/@VERSION@

找到org.apache.catalina.startup.VersionLoggerListener類的log()方法,打斷點(diǎn)一步一步跟蹤

最終發(fā)現(xiàn)所有的值存在了PropertyResourceBundle類的lookup的map集合中,集合中的數(shù)據(jù)已經(jīng)亂碼了。

于是繼續(xù)debugger查看lookup的加載,通過源碼查看lookup集合中的數(shù)據(jù)是從properties文件中讀取出來的。查看該properties文件編碼也是UTF-8。于是繼續(xù)查看源碼。

ResourceBundle中的is = classLoader.getResourceAsStream(resourceName);加載的這個(gè)properties文件

再通過PropertyResourceBundle構(gòu)造方法加載的數(shù)據(jù)。

正準(zhǔn)備修改這塊代碼時(shí),發(fā)現(xiàn)這竟是JDK中的類,無法修改。(后來才知道ResourceBundle是用來做國際化的)。

后來查資料知道了:在java中, 讀取文件的默認(rèn)格式是iso8859-1, 而我們中文存儲的時(shí)候一般是UTF-8. 所以導(dǎo)致讀出來的是亂碼。

解決方案有兩種:

1、使用JDK下的工具native2ascii.exe將properties文件轉(zhuǎn)為Unicode編碼。轉(zhuǎn)換后如圖:

2、在代碼中獲取到了值之后手動重新編碼解碼下

try {    value = new String(value.getBytes("ISO-8859-1"), "UTF-8");}catch(Exception e){    e.printStackTrace();}

經(jīng)過測試,兩種方法都可以解決問題。

因?yàn)閠omcat中properties文件過多,我采用了第二種方法,修改了tomcat源碼,修改如下:

1)org.apache.tomcat.util.res.StringManager類中的getString(final String key, final Object... args)方法。

2)org.apache.jasper.compiler.Localizer類的getMessage(String errCode)方法

至此,亂碼問題解決

總結(jié)

到此這篇關(guān)于一次tomcat源碼啟動控制臺中文亂碼調(diào)試過程記錄的文章就介紹到這了,更多相關(guān)tomcat源碼啟動控制臺中文亂碼內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!

標(biāo)簽: Tomcat
主站蜘蛛池模板: 欧美日韩精品国产一区二区 | 久草8| 男吃女下面刺激视频免费 | 亚洲精品国产综合99久久一区 | 亚洲免费片 | 欧美理论片在线观看一区二区 | 在线免费视频国产 | 一 级 黄 色 大片 | 欠草视频 | 男人免费看片 | 国产高清在线看免费视频观 | 一级黄色片aaa | 免费观看日本视频 | 国产精选莉莉私人影院 | 欧美色欧美色 | 福利视频专区 | 久久久成人啪啪免费网站 | 99精品国产成人一区二区在线 | 亚洲精品久久久久久久久久久网站 | 日韩精品久久久久久 | 99在线观看巨臀大臀视频 | 亚洲天天 | 国产精品视_精品国产免费 国产精品视频久 | 日韩精品亚洲人成在线观看 | 韩国三级 mp4 | 亚洲欧洲视频在线 | 国内精品久久久久久久影视麻豆 | 97在线免费视频 | 嫩模大尺度人体福利视频 | 亚洲一区二区三区精品视频 | 波多野结衣一区在线观看 | 日韩 欧美 中文 亚洲 高清 在线 | 欧美成人免费午夜影视 | 99视频有精品 | 亚洲一区二区三区四区在线观看 | 午夜福利国产一级毛片 | 亚洲视频日韩视频 | 日韩三级精品 | 美国毛片免费观看 | 91免费看国产 | 亚洲国产精品综合欧美 |