DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> AJAX入門 >> AJAX基礎知識 >> AJAX中文亂碼的兩類問題
AJAX中文亂碼的兩類問題
編輯:AJAX基礎知識     

AJAX中文問題分為兩大類:

1)發送路徑中的參數有中文,在服務器段接收參數值是亂碼

例如:

var url="a.jsp?name=小李";
xmlHTTP.open ("post",url,true);

解決辦法:

利用javascript的提供的escape()或encodeURI()方法

例如:

客戶端:

var url="a.jsp?name=小李";
url=encodeURI(url);
url=encodeURI(url); //兩次,很關鍵[具體為什麼,我也不清楚]
/********************************************/
也有人寫成var url="a.jsp?name=escape("小李")";

功能和encodeURI方法類似。

/********************************************/
xmlHTTP.setrequestheader("cache-control","no-cache");
xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");
xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定發送數據的編碼格式
xmlHTTP.open ("post",url,true);

服務器端:

String name = request.getParameter("name");
name = java.net.URLDecoder.decode("name", "UTF-8");

2)返回來的responseText或responseXML的值中含有中文是亂碼

原因:AJAX在接收responseText或responseXML的值的時候是按照UTF-8的格式來解碼的,如果服務器段發送的數據不是UTF-8的格式,那麼接收responseText或responseXML的值有可能為亂碼。

解決辦法:在服務器指定發送數據的格式:

在jsp文件中:

response.setContentType("text/text;charset=UTF-8");//返回的是txt文本文件

或是

response.setContentType("text/xml;charset=UTF-8");//返回的xml文件

總結:1)ajax提交數據的格式默認為utf-8,利用javascript的提供的escape()或encodeURI()方法.在服務器端接收的時候要使用Java.net.URLDecoder.decode("","UTF-8")方法進行解碼.

2)xtmlhttp 返回的數據默認的字符編碼是utf-8,所以服務器要向客戶端發送數據的時候,也要采用utf-8編碼

如果上述方法仍然解決不了亂碼問題,那你嘗試一下把jsp,htm,java文件用UTF-8編碼格式保存.

總之:前後台數據交互都采用utf-8編碼就行了.

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved