欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2021年06月01日 11:04:40   作者:zhoutaoping1992  
平時在使用tomcat做一些服務(wù)的時候經(jīng)常遇到各種亂碼問題,下面這篇文章主要給大家介紹了一次tomcat源碼啟動控制臺中文亂碼的調(diào)試過程,需要的朋友可以參考下

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

今天準備學(xué)習(xí)下tomcat源碼,于是從官網(wǎng)下載了tomcat的源碼,導(dǎo)入到IDEA中,使用maven工具build完項目之后,啟動項目,控制臺打印了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、修改項目下的.idea文件夾下的encodings.xml文件,不是UTF-8的改為UTF-8;

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

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

9、修改完重啟IDEA。

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

仔細觀察后,發(fā)現(xià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()方法,打斷點一步一步跟蹤

最終發(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);加載的這個properties文件

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

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

后來查資料知道了:在java中, 讀取文件的默認格式是iso8859-1, 而我們中文存儲的時候一般是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)過測試,兩種方法都可以解決問題。

因為tomcat中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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • tomcat訪問(access)日志配置和記錄Post請求參數(shù)

    tomcat訪問(access)日志配置和記錄Post請求參數(shù)

    這篇文章主要介紹了tomcat訪問(access)日志配置和記錄Post請求參數(shù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 在Tomcat中配置404自定義錯誤頁面詳解

    在Tomcat中配置404自定義錯誤頁面詳解

    這篇文章主要介紹了在Tomcat中配置404自定義錯誤頁面全解,需要的朋友可以參考下
    2017-03-03
  • 一次tomcat源碼啟動控制臺中文亂碼的調(diào)試過程記錄

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

    平時在使用tomcat做一些服務(wù)的時候經(jīng)常遇到各種亂碼問題,下面這篇文章主要給大家介紹了一次tomcat源碼啟動控制臺中文亂碼的調(diào)試過程,需要的朋友可以參考下
    2021-06-06
  • 修改Tomcat默認訪問根目錄的方法

    修改Tomcat默認訪問根目錄的方法

    這篇文章主要介紹了修改Tomcat默認訪問根目錄的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Tomcat實現(xiàn)WebSocket的方法

    Tomcat實現(xiàn)WebSocket的方法

    WebSocket協(xié)議屬于HTML5標準,越來越多瀏覽器已經(jīng)原生支持WebSocket,它能讓客戶端和服務(wù)端實現(xiàn)雙向通信。這篇文章主要介紹了Tomcat實現(xiàn)WebSocket的方法的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • Tomcat中Filter過濾器的具體使用

    Tomcat中Filter過濾器的具體使用

    Filter?是一種用于攔截請求和過濾響應(yīng)的組件,本文主要介紹了Tomcat中Filter過濾器的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • Eclipse創(chuàng)建tomcat實現(xiàn)過程原理詳解

    Eclipse創(chuàng)建tomcat實現(xiàn)過程原理詳解

    這篇文章主要介紹了Eclipse創(chuàng)建tomcat實現(xiàn)過程原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • IDEA部署項目到tomcat運行成功但是頁面404的兩種原因分析

    IDEA部署項目到tomcat運行成功但是頁面404的兩種原因分析

    這篇文章主要給大家介紹了關(guān)于IDEA部署項目到tomcat運行成功但是頁面404的兩種原因,這是最近在使用IDEA進行開發(fā)測試時遇到一個問題,需要的朋友可以參考下
    2023-08-08
  • tomcat9 下載安裝和配置+整合到eclipse的教程詳解

    tomcat9 下載安裝和配置+整合到eclipse的教程詳解

    這篇文章主要介紹了tomcat9 下載安裝和配置+整合到eclipse,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • tomcat默認最大連接數(shù)與調(diào)整的方法示例

    tomcat默認最大連接數(shù)與調(diào)整的方法示例

    本文主要介紹了tomcat默認最大連接數(shù)與調(diào)整的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05

最新評論