瀏覽器和服務(wù)器通信時(shí),許多常見的非文字?jǐn)?shù)字字符(如空格)不能以其原來的格式傳輸,只允許較少的字母、數(shù)字和符號(hào)傳輸。為了使用其他字符,字符必須使用特殊的符號(hào)(%)和十六進(jìn)制的ASCII值進(jìn)行編碼。例如,空格字符值是十六進(jìn)制的20(ASCII十進(jìn)制32),其編碼為%20。在瀏覽器歷史記錄或URL中可以見到這個(gè)符號(hào)。
參數(shù)中含有中文,不滿足URL字符串編碼,所以必須進(jìn)行轉(zhuǎn)碼。將含有中文的參數(shù)轉(zhuǎn)換成URL支持的字符串編碼,之后再進(jìn)行解碼即可。
3、如何解決前臺(tái)轉(zhuǎn)碼,后臺(tái)再解碼即可。當(dāng)然也可以2個(gè)都在前臺(tái)js或后臺(tái)java中進(jìn)行,本文只舉例前臺(tái)轉(zhuǎn)碼,后臺(tái)解碼的情況,其他情況道理一樣,自己靈活運(yùn)用。
3.1、前臺(tái)轉(zhuǎn)碼
JavaScript提供兩個(gè)函數(shù)escape()和unescape(),實(shí)現(xiàn)對(duì)字符串的即時(shí)轉(zhuǎn)換。將普通字符轉(zhuǎn)義為上述轉(zhuǎn)義代碼使用escape()函數(shù),unescape函數(shù)則將轉(zhuǎn)義代碼轉(zhuǎn)換為普通字符。但是不推薦用escape()和unescape(),我推薦用encodeURI()或encodeURIComponent(),因?yàn)檫@2者支持“統(tǒng)一資源標(biāo)識(shí)符”(URI);而escape不支持。至于3者的區(qū)別,可以閱讀下面分界線中的內(nèi)容。
如下:
var userName = document.getElementById("userName");
userName = encodeURI(userName);
myForm.submit();
其中,userName是myForm提交時(shí)的一個(gè)參數(shù)
在這里還要介紹一下escape()、encodeURI()、encodeURIComponent(),如果不需要,可以跳過分界線:
---------------------------------------傳說中的分界線-----------------------------------------
在用javascript對(duì)URL字符串進(jìn)行編碼中,雖然escape()、encodeURI()、encodeURIComponent()三種方法都能對(duì)一些影響URL完整性的特殊字符進(jìn)行過濾。但后兩者是將字符串轉(zhuǎn)換為UTF-8的方式來傳輸,解決了頁面編碼不一至導(dǎo)致的亂碼問題。例如:發(fā)送頁與接受頁的編碼格式(Charset)不一致(假設(shè)發(fā)送頁面是GB2312而接收頁面編碼是UTF-8),使用escape()轉(zhuǎn)換傳輸中文字串就會(huì)出現(xiàn)亂碼問題。
以下是JS下對(duì)URL進(jìn)行編/解碼的各種方法:
1、escape 方法:返回一個(gè)可在所有計(jì)算機(jī)上讀取的編碼 String 對(duì)象。
function escape(charString : String) : String
不會(huì)被此方法編碼的字符: @ * / +
說明:escape 方法返回一個(gè)包含 charstring 內(nèi)容的字符串值(Unicode 格式)。所有空格、標(biāo)點(diǎn)、
重音符號(hào)以及任何其他非 ASCII 字符都用 %xx 編碼替換,其中 xx 等于表示該字符的十六進(jìn)制數(shù)。
例如,空格返回為“%20”。(字符值大于 255 的字符以 %uxxxx 格式存儲(chǔ)。)
注意:escape 方法不能用來對(duì)“統(tǒng)一資源標(biāo)識(shí)符”(URI) 進(jìn)行編碼。對(duì)其編碼應(yīng)使用 encodeURI 和encodeURIComponent 方法。
2、encodeURI 方法:返回編碼為有效的統(tǒng)一資源標(biāo)識(shí)符 (URI) 的字符串。
function encodeURI(URIString : String) : String
不會(huì)被此方法編碼的字符:! @ # $ & * ( ) = : / ; ? + '
說明:encodeURI 方法返回一個(gè)已編碼的 URI。如果將編碼結(jié)果傳遞給 decodeURI,則將返回初始的字符串。encodeURI 不對(duì)下列字符進(jìn)行編碼:“:”、“/”、“;”和“?”。請(qǐng)使用
encodeURIComponent 對(duì)這些字符進(jìn)行編碼。
3、encodeURIComponent 方法:返回編碼為統(tǒng)一資源標(biāo)識(shí)符 (URI) 的有效組件的字符串。
function encodeURIComponent(encodedURIString : String) : String
不會(huì)被此方法編碼的字符:! * ( ) '
說明:encodeURIComponent 方法返回一個(gè)已編碼的 URI。如果將編碼結(jié)果傳遞給decodeURIComponent,則將返回初始的字符串。因?yàn)?encodeURIComponent 方法將對(duì)所有字符編碼,
請(qǐng)注意,如果該字符串代表一個(gè)路徑,例如 /folder1/folder2/default.html,則其中的斜杠也將被編碼,這樣,當(dāng)該字符串作為請(qǐng)求發(fā)送到 Web 服務(wù)器時(shí)它將是無效的。如果字符串中包含多個(gè) URI 組件,請(qǐng)使用 encodeURI 方法進(jìn)行編碼。
4、unescape 方法:從用 escape 方法編碼的 String 對(duì)象中返回已解碼的字符串。
function unescape(charString : String) : String
說明:unescape 方法返回一個(gè)包含 charstring 內(nèi)容的字符串值。所有以 %xx 十六進(jìn)制形式編碼的
字符都用 ASCII 字符集當(dāng)中等效的字符代替。(以 %uxxxx 格式(Unicode 字符)編碼的字符用十六
進(jìn)制編碼 xxxx 的 Unicode 字符代替。)
注意:unescape 方法不應(yīng)用于解碼“統(tǒng)一資源標(biāo)識(shí)符”(URI)。請(qǐng)改用 decodeURI 和 decodeURIComponent 方法。
5、decodeURI 方法:返回一個(gè)已編碼的統(tǒng)一資源標(biāo)識(shí)符 (URI) 的非編碼形式。
function decodeURI(URIstring : String) : String
decodeURIComponent 方法:返回統(tǒng)一資源標(biāo)識(shí)符 (URI) 的一個(gè)已編碼組件的非編碼形式。
function decodeURIComponent(encodedURIString : String) : String
BTW:C#中對(duì)URL編碼的方法。。。
編碼:Server.UrlEncode(string)
解碼:Server.UrlDecode(string) 前面三種客戶端編碼都可以用這個(gè)方法在后臺(tái)解碼。
---------------------------------------分界線完-----------------------------------------
3.2、后臺(tái)解碼
String paramStr = (String)request.getParameter("userName");
paramStr = URLDecoder.decode(paramStr,"utf-8");
其中,userName是前臺(tái)傳過來的參數(shù)。如果用escape()的話,解碼是不能用URLDecoder.decode()的。