html 中文亂碼 HTML超鏈接中文亂碼問題分析及解決方法
發(fā)布時間:2012-12-30 16:54:52 作者:佚名
我要評論
Vm中一個超鏈接URL需要拼接中文作為Get請求的參數(shù)如果直接拼接,傳到后臺Action的參數(shù)對象中后取出會是亂碼,需要編碼后再拼接到URL上,接下來將和大家分享一下解決方法
Vm中一個超鏈接URL需要拼接中文作為Get請求的參數(shù)。如果直接拼接,傳到后臺Action的參數(shù)對象中后取出會是亂碼,需要編碼后再拼接到URL上。
解決方法是在Action中添加一個成員變量,保存編碼后的中文參數(shù)。在vm頁面渲染時取出這個變量值,再拼接超鏈接。
在這里碰到的問題是:調(diào)用java.net.URLEncoder的encode()方法時,如果沒有顯示指定字符集參數(shù),那么URLEncoder會使用默認(rèn)字符集。這個默認(rèn)字符集在Eclipse里跑main()方法和在Tomcat里跑Web應(yīng)用,得到的結(jié)果不一樣,所以影響了編碼的結(jié)果。
/**
* Translates a string into <code>x-www-form-urlencoded</code>
* format. This method uses the platform'sdefault encoding
* as the encoding scheme to obtain thebytes for unsafe characters.
*
* @param s <code>String</code> to betranslated.
* @deprecated The resulting string mayvary depending on the platform's
* default encoding. Instead, use theencode(String,String)
* method to specify the encoding.
* @return the translated <code>String</code>.
*/
@Deprecated
public static String encode(String s) {
String str = null;
try {
str = encode(s, dfltEncName);
} catch(UnsupportedEncodingException e) {
// The system should always have theplatform default
}
return str;
}
方法的注釋中也說明了不建議使用的原因是,這個encode(String)方法依賴于平臺字符集。
解決方法是在Action中添加一個成員變量,保存編碼后的中文參數(shù)。在vm頁面渲染時取出這個變量值,再拼接超鏈接。
在這里碰到的問題是:調(diào)用java.net.URLEncoder的encode()方法時,如果沒有顯示指定字符集參數(shù),那么URLEncoder會使用默認(rèn)字符集。這個默認(rèn)字符集在Eclipse里跑main()方法和在Tomcat里跑Web應(yīng)用,得到的結(jié)果不一樣,所以影響了編碼的結(jié)果。
復(fù)制代碼
代碼如下:/**
* Translates a string into <code>x-www-form-urlencoded</code>
* format. This method uses the platform'sdefault encoding
* as the encoding scheme to obtain thebytes for unsafe characters.
*
* @param s <code>String</code> to betranslated.
* @deprecated The resulting string mayvary depending on the platform's
* default encoding. Instead, use theencode(String,String)
* method to specify the encoding.
* @return the translated <code>String</code>.
*/
@Deprecated
public static String encode(String s) {
String str = null;
try {
str = encode(s, dfltEncName);
} catch(UnsupportedEncodingException e) {
// The system should always have theplatform default
}
return str;
}
方法的注釋中也說明了不建議使用的原因是,這個encode(String)方法依賴于平臺字符集。
相關(guān)文章
- 寫HTML5代碼時發(fā)現(xiàn)中文顯示亂碼,之前以為是不兼容IE10、然后換成火狐,誰知也不行,經(jīng)反復(fù)研究測試,尋得個不錯的解決方法,有類似情況的朋友可以參考下2013-11-18
- HTML5 UTF-8出現(xiàn)中文亂碼的情況,應(yīng)該有很多的朋友都有遇到吧,用記事本寫,保存后在網(wǎng)頁上運(yùn)行出現(xiàn)了亂碼,換成GB2312能正確顯示中文,下面就為大家探討下具體的解決方法2013-11-18
- 我今天的頁面也是出現(xiàn)了亂碼,所以在網(wǎng)上查找了相關(guān)的問題,看來一下,這個方法挺不錯的,我也試驗了呢,我用的editp編輯器,在文檔—文件編碼—更改文件編碼—選擇自己所2013-02-26
今天遇到個問題就是寫的HTML代碼打開顯示的是亂碼問題,怎么處理這一問題呢,下面小編通過圖文實例相結(jié)合給大家分享處理方法,一起看看吧2021-09-02


