久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術文章
文章詳情頁

java中servlet過濾器解決中文亂碼問題的一絲疑惑,這里必須要用entrySet遍歷嗎?

瀏覽:145日期:2023-11-14 17:11:21

問題描述

網(wǎng)上查到的關于解決中文亂碼問題的過濾器代碼中都有類似下面的這一段:

Map<String,String[]> map = request.getParameterMap();//獲取有亂碼的map if(isNotEncode){//只能在第一次解決亂碼 for(Map.Entry<String, String[]> entry : map.entrySet()){//遍歷map,解決所有值的亂碼 String [] vs = entry.getValue(); for(int i=0;i<vs.length;i++){ vs[i] = new String(vs[i].getBytes('iso8859-1'),encode); } } isNotEncode = false;//設置為false,第二次就不會再進這個代碼塊了 } return map;

這里只是修改了map里面的值集,此值集是String數(shù)組的集合,實際只是修改了String數(shù)組里的元素。我感覺這里沒有必要取出entrySet并遍歷,只用取出Values并遍歷就可以達到同樣的效果,我親自實踐了一下也證實我的猜想。但是我在網(wǎng)上看到的資料幾乎都是遍歷entrySet,這是為什么?只遍歷值集Values有什么漏洞嗎?望高手解惑!

問題解答

回答1:

你的意思是這樣吧:

for (String[] values : map.values()) { for (int i = 0; i < values.length; i ++) {values[i] = new String(values[i].getBytes(StandardCharsets.ISO_8859_1, encode)); }}

我覺得沒啥不可以的呀。

回答2:

完全沒有必要,見Tomcat的SetCharacterEncodingFilter的源碼

request.setCharacterEncoding(...)

標簽: java
主站蜘蛛池模板: 大化| 东宁县| 永清县| 高青县| 乌拉特后旗| 平利县| 巨鹿县| 蛟河市| 黑河市| 西林县| 寻乌县| 韩城市| 桐柏县| 宣城市| 宜川县| 恩施市| 武山县| 平乐县| 威宁| 舟山市| 建水县| 铜山县| 来安县| 得荣县| 民乐县| 双江| 密山市| 蕉岭县| 洛浦县| 镇巴县| 娱乐| 准格尔旗| 福清市| 密云县| 宁河县| 万山特区| 德江县| 阳春市| 读书| 大邑县| 呼和浩特市|