ajax中文亂碼的各種解決辦法總結(jié)_AJAX教程
推薦:AJAX中文亂碼PHP中完美解決方法AJAX中文亂碼問(wèn)題,經(jīng)過(guò)一個(gè)下午的努力終于完美解決,現(xiàn)將心得寫(xiě)下來(lái),希望對(duì)那些還困繞在這個(gè)問(wèn)題而頭痛不已的人們有所幫助
由于XMLHTTP采用的是Unicode編碼上傳數(shù)據(jù),而一般頁(yè)面采用的是gb2312,這就造成顯示頁(yè)面時(shí)產(chǎn)生亂碼.而當(dāng)在獲取頁(yè)面時(shí)的XMLHttp返回的是utf-8編碼,這就造成了顯示產(chǎn)生亂碼.有一種解決辦法就是使用encodeURIComponent加上修改 Content-Type 為 application/x-www-form-urlencoded" 來(lái)把數(shù)據(jù)統(tǒng)一編碼成 url 格式,當(dāng)然,也可以指定編碼,如:“application/x-www-form-urlencoded; charset=utf-8 ”,
解決方法之一
例子:
復(fù)制代碼 代碼如下:hl5o.cn
http_request = new ActiveXObject("Msxml2.XMLHTTP");
http_request.setrequestheader("content-type","application/x-www-form-urlencoded; charset=utf-8");
解決方法之二
就是在PHP文件中顯示聲明為GB2312
復(fù)制代碼 代碼如下:hl5o.cn
header("Content-Type:text/html;charset=GB2312");
而對(duì)于發(fā)送到服務(wù)器的中文進(jìn)行轉(zhuǎn)碼.
如下
復(fù)制代碼 代碼如下:hl5o.cn
<?php
header("Content-Type:text/html;charset=GB2312");
if($_POST['content'])
{
$_POST["content"]=iconv("UTF-8","gb2312",$_POST["content"]);
}
else
{
print("沒(méi)有內(nèi)容發(fā)送");
}
?>
因而這樣可以解決亂碼問(wèn)題
jsp中ajax中文亂碼
發(fā)送路徑中的參數(shù)有中文,在服務(wù)器段接收參數(shù)值是亂碼
例如:
var url="a.jsp?name=小李";
xmlHTTP.open ("post",url,true);
解決辦法:
利用javascript的提供的escape()或encodeURI()方法
例如:
客戶(hù)端:
復(fù)制代碼 代碼如下:hl5o.cn
var url="a.jsp?name=小李";
url=encodeURI(url);
url=encodeURI(url); //兩次,很關(guān)鍵[具體為什么,我也不清楚]
/********************************************/
也有人寫(xiě)成var url="a.jsp?name=escape("小李")";
功能和encodeURI方法類(lèi)似。
復(fù)制代碼 代碼如下:hl5o.cn
/********************************************/
xmlHTTP.setrequestheader("cache-control","no-cache");
xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");
xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定發(fā)送數(shù)據(jù)的編碼格式
xmlHTTP.open ("post",url,true);
服務(wù)器端:
復(fù)制代碼 代碼如下:hl5o.cn
String name = request.getParameter("name");
name = java.net.URLDecoder.decode("name", "UTF-8");
2)返回來(lái)的responseText或responseXML的值中含有中文是亂碼
原因:AJAX在接收responseText或responseXML的值的時(shí)候是按照UTF-8的格式來(lái)解碼的,如果服務(wù)器段發(fā)送的數(shù)據(jù)不是UTF-8的格式,那么接收responseText或responseXML的值有可能為亂碼。
解決辦法:在服務(wù)器指定發(fā)送數(shù)據(jù)的格式:
在jsp文件中:
response.setContentType("text/text;charset=UTF-8");//返回的是txt文本文件
或是
response.setContentType("text/xml;charset=UTF-8");//返回的xml文件
| gb2312 | jquery ajax 獲取數(shù)據(jù) | gb2312 | 是 | jsp:<%@page contentType="application/json" pageEncoding="gb2312"%>這里用的json作測(cè)試,與text/html應(yīng)該一樣 aps:Response.Charset="gb2312"(參照網(wǎng)絡(luò)未測(cè)試) php:header("Content-Type:text/html; charset=gb2312");(參照網(wǎng)絡(luò)未測(cè)試) html:未解決 |
| gb2312 | jquery ajax 獲取數(shù)據(jù) | utf-8 | 否 | |
| utf-8 | jquery ajax 獲取數(shù)據(jù) | utf-8 | 否 | |
| utf-8 | jquery ajax 獲取數(shù)據(jù) | gb2312 | 是 | jsp:<%@page contentType="application/json" pageEncoding="gb2312"%>這里用的json作測(cè)試,與text/html應(yīng)該一樣 aps:Response.Charset="gb2312"(參照網(wǎng)絡(luò)未測(cè)試) php:header("Content-Type:text/html; charset=gb2312");(參照網(wǎng)絡(luò)未測(cè)試) html:未解決 |
分享:Ajax與JSON的一些學(xué)習(xí)總結(jié)Ajax技術(shù)的核心是XMLHttpRequest對(duì)象(簡(jiǎn)稱(chēng)XHR),可以通過(guò)使用XHR對(duì)象獲取到服務(wù)器的數(shù)據(jù),然后再通過(guò)DOM將數(shù)據(jù)插入到頁(yè)面中呈現(xiàn)。雖然名字中包含XML,但Ajax通訊與數(shù)據(jù)格式無(wú)關(guān),所以我們的數(shù)據(jù)格式可以是XML或JSON等格式
相關(guān)AJAX教程:
- Ajax中瀏覽器的緩存問(wèn)題解決方法
- AJAX和WebService實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)具體代碼
- ajax 登錄功能簡(jiǎn)單實(shí)現(xiàn)(未連接數(shù)據(jù)庫(kù))
- AJAX和WebService實(shí)現(xiàn)郵箱驗(yàn)證(無(wú)刷新驗(yàn)證郵件地址是否合法)
- AJAX和三層架構(gòu)實(shí)現(xiàn)分頁(yè)功能具體思路及代碼
- 使用AJAX返回WebService里的集合具體實(shí)現(xiàn)
- AJAX獲取服務(wù)器當(dāng)前時(shí)間及時(shí)間格式輸出處理
- ajax傳遞多個(gè)參數(shù)具體實(shí)現(xiàn)
- ajax傳遞一個(gè)參數(shù)具體實(shí)現(xiàn)
- 滑輪滾動(dòng)到頁(yè)面底部ajax加載數(shù)據(jù)配合jsonp實(shí)現(xiàn)探討
- jQery ajax——load()方法示例介紹
- jQuery+Ajax實(shí)現(xiàn)表格數(shù)據(jù)不同列標(biāo)題排序(為表格注入活力)
AJAX教程Rss訂閱編程教程搜索
AJAX教程推薦
- Ajax如何實(shí)現(xiàn)靜態(tài)頁(yè)面分頁(yè)
- 用AJAX編寫(xiě)用戶(hù)注冊(cè)實(shí)例及技術(shù)小結(jié)
- 解讀jsp+ajax自動(dòng)刷新實(shí)例
- XMLHTTP異步獲取返回值的代碼超時(shí)測(cè)試(AJAX)
- Ajax標(biāo)簽導(dǎo)航實(shí)例詳解-Javascript技巧篇
- 解析Ajax實(shí)例教程-----級(jí)聯(lián)菜單
- 掌握 Ajax,第 1 部分 Ajax 簡(jiǎn)介
- ajax 登錄功能簡(jiǎn)單實(shí)現(xiàn)(未連接數(shù)據(jù)庫(kù))
- 使用AJAX技術(shù)實(shí)現(xiàn)網(wǎng)頁(yè)無(wú)閃自動(dòng)局部刷新
- 淺析AJAX中JavaScript類(lèi)的三種成員
猜你也喜歡看這些
- AJAX獲取服務(wù)器當(dāng)前時(shí)間及時(shí)間格式輸出處理
- Ajax 中的高級(jí)請(qǐng)求和響應(yīng)
- 使用AJAX技術(shù)打造博客無(wú)刷新搜索引擎
- Ajax請(qǐng)求中的異步與同步,需要注意的地方說(shuō)明
- 詳解Ajax標(biāo)簽導(dǎo)航實(shí)例
- AJAX實(shí)例入門(mén)
- 雙劍合璧 Ajax和RSS做個(gè)人門(mén)戶(hù)網(wǎng)站
- 如何結(jié)合MS AJAX將js文件編譯到動(dòng)態(tài)鏈接庫(kù)
- AJAX技術(shù)開(kāi)發(fā)Back按鈕問(wèn)題的應(yīng)用程序
- 掌握Ajax第2部分使用
- 相關(guān)鏈接:
- 教程說(shuō)明:
AJAX教程-ajax中文亂碼的各種解決辦法總結(jié)
。