JS中encodeURIComponent函數(shù)用php解碼的代碼
更新時間:2012年03月01日 15:43:02 作者:
在JS中使用了encodeURIComponent對中文進(jìn)行編碼在PHP中使用iconv('UTF-8','gb2312',$q);就可以得到你需要的字串了,其中g(shù)b2312根據(jù)你實際應(yīng)用來定如還不明白為什么看下面的文章
JS中encodeURIComponent函數(shù)給中文編碼后,如何用php解碼??
前提:編碼前的中文可能是gbk,gb2312,utf-8等。
urldecode()
iconv()
在JS中使用了encodeURIComponent對中文進(jìn)行編碼在PHP中使用iconv('UTF-8','gb2312',$q);就可以得到你需要的字串了,其中g(shù)b2312根據(jù)你實際應(yīng)用來定如還不明白為什么看下面的文章
URL編碼轉(zhuǎn)換,escape() encodeURI() encodeURIComponent()
本文介紹對url編碼的三種函數(shù) escape() ,encodeURI() ,encodeURIComponent()
escape() 方法:
采用ISO Latin字符集對指定的字符串進(jìn)行編碼。所有的空格符、標(biāo)點符號、特殊字符以及其他非ASCII字符都將被轉(zhuǎn)化成%xx格式的字符編碼(xx等于該字符在字符集表里面的編碼的16進(jìn)制數(shù)字)。比如,空格符對應(yīng)的編碼是%20。unescape方法與此相反。不會被此方法編碼的字符: @ * / +
encodeURI() 方法:
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。不會被此方法編碼的字符:! @ # $& * ( ) = : / ; ? + '
encodeURIComponent() 方法:
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。與encodeURI()相比,這個方法將對更多的字符進(jìn)行編碼,比如 / 等字符。所以如果字符串里面包含了URI的幾個部分的話,不能用這個方法來進(jìn)行編碼,否則 / 字符被編碼之后URL將顯示錯誤。不會被此方法編碼的字符:! * ( )
因此,對于中文字符串來說,如果不希望把字符串編碼格式轉(zhuǎn)化成UTF-8格式的(比如原頁面和目標(biāo)頁面的charset是一致的時候),只需要使用escape。如果你的頁面是GB2312或者其他的編碼,而接受參數(shù)的頁面是UTF-8編碼的,就要采用encodeURI或者encodeURIComponent。
注意:escape 方法不能用來對“統(tǒng)一資源標(biāo)識符”(uri) 進(jìn)行編碼。對其編碼應(yīng)使用 encodeuri 和 encodeuricomponent 方法。另外,encodeURI/encodeURIComponent是在javascript1.5之后引進(jìn)的,escape則在javascript1.0版本就有。
總結(jié)一下用法:
1、HTTP/POST方式在缺省情況下,采用的是“x-www-form-urlencoded”進(jìn)行編碼,它和JavaScript里面的encodeURI所起的作用是一樣的;
2、經(jīng)過這樣編碼的內(nèi)容,到達(dá)后臺時,其中的字符都是UTF-8編碼格式的;
3、如果你的Servlet/JSP指定輸出使用的Content-Type是UTF-8,恭喜你,你不需要對這些Parameters進(jìn)行特別的編碼、解碼操作,它一定是正常的;
4、否則你需要對這些parameter進(jìn)行解、編碼操作,例如你的頁面是GBK編碼,那么你需要這么寫:
String sPara = new String(request.getParamter("test").getBytes("iso-8859-1"),"GBK");
采用gb2312編碼的也可以采用GBK編碼;
5、如果你是在eclipse中進(jìn)行工作,請注意你的Servlet和JSP文件的屬性,其中的編碼必須和content-type中設(shè)置的一樣,否則javac會對你的文件進(jìn)行錯誤的編碼,這時候的字節(jié)碼文件本身的字符串就是錯誤的,輸出也不頂用;
6、最后做一個總結(jié):
6.1、servlet/JSP文件本身的編碼必須和content-type輸出的一致,否則需要加入額外的編碼、解碼步驟;
6.2、HTTP/POST方式和encodeURI方式傳入的編碼都是UTF-8的;
6.3、普通的window.open(...),也就是HTTP/GET方式,其傳入的編碼是和運行script的頁面編碼一致的;
6.4、后臺解碼必須通過iso-8859-1進(jìn)行解碼,再使用你的目標(biāo)編碼進(jìn)行編碼;
6.5、 response.setContentType("text/xml;charset=utf-8");
如有漢字回顯至頁面,須加charset=utf-8字樣
request.setCharacterEncoding("UTF-8");//頁面如通過POST過來,含有漢字,須加這一句
此語句放在程序最前面;
6.6 請保證項目屬性編碼為"UTF-8",請求頁面與響應(yīng)頁面編碼一致(可以是后臺)UTF-8.必須保證文件
屬性和ContentType設(shè)置一致
前提:編碼前的中文可能是gbk,gb2312,utf-8等。
復(fù)制代碼 代碼如下:
urldecode()
iconv()
在JS中使用了encodeURIComponent對中文進(jìn)行編碼在PHP中使用iconv('UTF-8','gb2312',$q);就可以得到你需要的字串了,其中g(shù)b2312根據(jù)你實際應(yīng)用來定如還不明白為什么看下面的文章
URL編碼轉(zhuǎn)換,escape() encodeURI() encodeURIComponent()
本文介紹對url編碼的三種函數(shù) escape() ,encodeURI() ,encodeURIComponent()
escape() 方法:
采用ISO Latin字符集對指定的字符串進(jìn)行編碼。所有的空格符、標(biāo)點符號、特殊字符以及其他非ASCII字符都將被轉(zhuǎn)化成%xx格式的字符編碼(xx等于該字符在字符集表里面的編碼的16進(jìn)制數(shù)字)。比如,空格符對應(yīng)的編碼是%20。unescape方法與此相反。不會被此方法編碼的字符: @ * / +
encodeURI() 方法:
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。不會被此方法編碼的字符:! @ # $& * ( ) = : / ; ? + '
encodeURIComponent() 方法:
把URI字符串采用UTF-8編碼格式轉(zhuǎn)化成escape格式的字符串。與encodeURI()相比,這個方法將對更多的字符進(jìn)行編碼,比如 / 等字符。所以如果字符串里面包含了URI的幾個部分的話,不能用這個方法來進(jìn)行編碼,否則 / 字符被編碼之后URL將顯示錯誤。不會被此方法編碼的字符:! * ( )
因此,對于中文字符串來說,如果不希望把字符串編碼格式轉(zhuǎn)化成UTF-8格式的(比如原頁面和目標(biāo)頁面的charset是一致的時候),只需要使用escape。如果你的頁面是GB2312或者其他的編碼,而接受參數(shù)的頁面是UTF-8編碼的,就要采用encodeURI或者encodeURIComponent。
注意:escape 方法不能用來對“統(tǒng)一資源標(biāo)識符”(uri) 進(jìn)行編碼。對其編碼應(yīng)使用 encodeuri 和 encodeuricomponent 方法。另外,encodeURI/encodeURIComponent是在javascript1.5之后引進(jìn)的,escape則在javascript1.0版本就有。
總結(jié)一下用法:
1、HTTP/POST方式在缺省情況下,采用的是“x-www-form-urlencoded”進(jìn)行編碼,它和JavaScript里面的encodeURI所起的作用是一樣的;
2、經(jīng)過這樣編碼的內(nèi)容,到達(dá)后臺時,其中的字符都是UTF-8編碼格式的;
3、如果你的Servlet/JSP指定輸出使用的Content-Type是UTF-8,恭喜你,你不需要對這些Parameters進(jìn)行特別的編碼、解碼操作,它一定是正常的;
4、否則你需要對這些parameter進(jìn)行解、編碼操作,例如你的頁面是GBK編碼,那么你需要這么寫:
String sPara = new String(request.getParamter("test").getBytes("iso-8859-1"),"GBK");
采用gb2312編碼的也可以采用GBK編碼;
5、如果你是在eclipse中進(jìn)行工作,請注意你的Servlet和JSP文件的屬性,其中的編碼必須和content-type中設(shè)置的一樣,否則javac會對你的文件進(jìn)行錯誤的編碼,這時候的字節(jié)碼文件本身的字符串就是錯誤的,輸出也不頂用;
6、最后做一個總結(jié):
6.1、servlet/JSP文件本身的編碼必須和content-type輸出的一致,否則需要加入額外的編碼、解碼步驟;
6.2、HTTP/POST方式和encodeURI方式傳入的編碼都是UTF-8的;
6.3、普通的window.open(...),也就是HTTP/GET方式,其傳入的編碼是和運行script的頁面編碼一致的;
6.4、后臺解碼必須通過iso-8859-1進(jìn)行解碼,再使用你的目標(biāo)編碼進(jìn)行編碼;
6.5、 response.setContentType("text/xml;charset=utf-8");
如有漢字回顯至頁面,須加charset=utf-8字樣
request.setCharacterEncoding("UTF-8");//頁面如通過POST過來,含有漢字,須加這一句
此語句放在程序最前面;
6.6 請保證項目屬性編碼為"UTF-8",請求頁面與響應(yīng)頁面編碼一致(可以是后臺)UTF-8.必須保證文件
屬性和ContentType設(shè)置一致
您可能感興趣的文章:
- javascript HTMLEncode HTMLDecode的完整實例(兼容ie和火狐)
- php中json_decode()和json_encode()的使用方法
- js中encode、decode的應(yīng)用說明
- javascript encodeURI和encodeURIComponent的比較
- 淺析php中json_encode()和json_decode()
- php數(shù)組轉(zhuǎn)換js數(shù)組操作及json_encode的用法詳解
- JS的encodeURI和java的URLDecoder.decode使用介紹
- php中json_encode UTF-8中文亂碼的更好解決方法
- JS對URL字符串進(jìn)行編碼/解碼分析
- javascript另類方法實現(xiàn)htmlencode()與htmldecode()函數(shù)實例分析
相關(guān)文章
php鏈?zhǔn)讲僮鱩ysql數(shù)據(jù)庫(封裝類帶使用示例)
本文代碼將一些簡單常用的SQL語句,拆分、封裝成鏈?zhǔn)胶瘮?shù)與終結(jié)函數(shù),鏈?zhǔn)讲僮鳑]有先后之分,實現(xiàn)傻瓜式mysql數(shù)據(jù)庫操作。?同時學(xué)習(xí)下靜態(tài)成員函數(shù),實現(xiàn)鏈?zhǔn)讲僮鞯木唧w語法。2023-02-02PHP 處理TXT文件(打開/關(guān)閉/檢查/讀取)
php寫入txt、php讀取txt,在PHP處理TXT文件時經(jīng)常會使用到,本文整理了一些相關(guān)代碼,感興趣的朋友可以參考下哈2013-05-05PHP strip_tags()去除HTML、XML以及PHP的標(biāo)簽介紹
這篇文章主要介紹了PHP strip_tags()去除HTML、XML以及PHP的標(biāo)簽介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02解析如何修改phpmyadmin中的默認(rèn)登陸超時時間
本篇文章是對修改phpmyadmin中的默認(rèn)登陸超時時間的解決方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06