好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 一次tomcat源碼啟動控制臺中文亂碼的調試過程記錄

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

熱門標簽:400電話辦理介紹信 福州企業電銷機器人排名 上海申請高400開頭的電話 麗江真人語音電話外呼系統 宿城區電話機器人找哪家 怎么找到沒有地圖標注的店 打400電話怎么辦理收費 10086外包用的什么外呼系統 河南防封號電銷機器人是什么

發現問題

今天準備學習下tomcat源碼,于是從官網下載了tomcat的源碼,導入到IDEA中,使用maven工具build完項目之后,啟動項目,控制臺打印了tomcat日志,但是中文都是亂碼。

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

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

2、修改run/debug configurations,添加Enviroment variables參數: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。

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

仔細觀察后,發現日志左邊的日志等級”信息”和”嚴重”之類的中文亂碼解決了,但是日志中還有亂碼。

感覺應該是代碼的問題,于是決定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()方法,打斷點一步一步跟蹤

最終發現所有的值存在了PropertyResourceBundle類的lookup的map集合中,集合中的數據已經亂碼了。

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

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

再通過PropertyResourceBundle構造方法加載的數據。

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

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

解決方案有兩種:

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

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

        try {

            value = new String(value.getBytes("ISO-8859-1"), "UTF-8");

        }catch(Exception e){

            e.printStackTrace();

        }

經過測試,兩種方法都可以解決問題。

因為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)方法

至此,亂碼問題解決

總結

到此這篇關于一次tomcat源碼啟動控制臺中文亂碼調試過程記錄的文章就介紹到這了,更多相關tomcat源碼啟動控制臺中文亂碼內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

標簽:荊門 連云港 遵義 雞西 朝陽 面試通知 運城 隴南

巨人網絡通訊聲明:本文標題《一次tomcat源碼啟動控制臺中文亂碼的調試過程記錄》,本文關鍵詞  一次,tomcat,源碼,啟動,控制臺,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《一次tomcat源碼啟動控制臺中文亂碼的調試過程記錄》相關的同類信息!
  • 本頁收集關于一次tomcat源碼啟動控制臺中文亂碼的調試過程記錄的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 脱了小裙子扒了小内裤视频| 91探花在线播放| 韩国三级日本三级人与波| 女人做爰高潮全过程免| 国产激情视频在线观看的| 韩国版色戒| 太紧了夹得我的巴好爽| 国产精品一二| 黑人和我在厨房猛烈进出视频| 欧美交性a视频免费| 2019国内精品久久久久久| 国产精品国产三级国产AⅤ在线| 理论片午午伦夜理片免费版| 免费xxx成年大片| 成人性动漫高清免费观看| 双腿挂他肩上撞击轻哼h| 国产又粗又猛又爽又黄的AV视频| 亚洲国产精品97久久无色无码| 美女跪下吃男人的J8视频| 亚洲一卡2卡三卡4卡2021四卡 | 国产精品偷伦视频免费手机播放| 国产~aaaaa熟sao妇视频| 娇小videodes性爽HD的特点与评价| 国产成人啪精品视频免费软件| 男人的天堂久久精品激情a | 国产精品久久欧美日韩| 欧美多毛男Gay又粗又长| 性感美女的逼| 女人把扒开给男人爽的| 免费观看9999网站直播| 伦理女职员精油按摩HD高清| 女教师~被婬辱の教室蜜臀AV| 亚洲综合站| 亚洲欧美久久精品1区2区| chinese紧缚bdsm系列| 绯色AV蜜臀AV无码亚洲| 爽爽爽男女爽视频免费动漫| 成本人3d动漫视频在线看| 污黄软件| 最近电影观看免费完整版高清| 鲤鱼乡壮汉受合不拢腿|