URL編碼方法有3種
escape() ,unescape() encodeURI(),decodeURI() encodeURIComponent(),decodeURIComponent() 這幾種編碼所起的作用各不相同
escape() 方法:
採用ISO Latin字元集對指定的字串進行編碼。所有的空格符、標點符號、特殊字元以及其他非ASCII字元都將被轉化成%xx格式的字元編碼(xx等於該字元在字元集表裡面的編碼的16進位數字)。比如,空格符對應的編碼是%20。
不會被此方法編碼的字元: @ * / +
encodeURI() 方法:
把URI字串採用UTF-8編碼格式轉化成escape格式的字串。
不會被此方法編碼的字元:! @ # $& * ( ) = : / ; ? + '
encodeURIComponent() 方法:
把URI字串採用UTF-8編碼格式轉化成escape格式的字串。與encodeURI()相比,這個方法將對更多的字元進行編碼,比如 / 等字元。所以如果字串裡麵包含了URI的幾個部分的話,不能用這個方法來進行編碼,否則 / 字元被編碼之後URL將顯示錯誤。
不會被此方法編碼的字元:! * ( ) '
因此,對於中文字串來說,如果不希望把字串編碼格式轉化成UTF-8格式的(比如原頁面和目標頁面的charset是一致的時候),只需要使用escape。如果你的頁面是GB2312或者其他的編碼,而接受參數的頁面是UTF-8編碼的,就要採用encodeURI或者encodeURIComponent。
在後台JAVA處理函數:
JS是:escape()函數
Java是:
java.net.URLEncoder.encode()
java.net.URLDecoder.decode()
但是這個函數已經不推薦使用了
現在推薦使用
java.net.URLEncoder.encode(str,encode);
java.net.URLDecoder.decode(str,encode);
這樣就構成了統一的編碼格式下面舉簡單的個例子:
在伺服器端:
String encode=java.net.URLEncoder.encode( "大家好 ", "utf-8 ");
//encode=( "%E5%A4%A7%E5%AE%B6%E5%A5%BD "
String decode=java.net.URLDecoder.decode( "%E5%A4%A7%E5%AE%B6%E5%A5%BD ", "utf-8 ");
用戶端解碼Javascript:
decodeURIComponent(xmlHttp.responseText);
用戶端傳送時編碼:
encodeURIComponent( "大家好 ")
或
encodeURI( "大家好 ")
這樣就可以解決中文亂碼編碼問題了