由于XMLHTTP采用的是Unicode編碼上傳數據,而一般頁面采用的是gb2312,這就造成顯示頁面時產生亂碼.而當在獲取頁面時的XMLHttp返回的是utf-8編碼,這就造成了顯示產生亂碼.
有一種解決辦法就是使用encodeURIComponent加上修改 Content-Type 為 application/x-www-form-urlencoded" 來把數據統一編碼成 url 格式,當然,也可以指定編碼,如:“application/x-www-form-urlencoded; charset=utf-8 ”,
解決方法之一
例子:
復制代碼 代碼如下:
http_request = new ActiveXObject("Msxml2.XMLHTTP");
http_request.setrequestheader("content-type","application/x-www-form-urlencoded; charset=utf-8");
解決方法之二
就是在PHP文件中顯示聲明為GB2312
復制代碼 代碼如下:
header("Content-Type:text/html;charset=GB2312");
而對于發送到服務器的中文進行轉碼.
如下
復制代碼 代碼如下:
?php
header("Content-Type:text/html;charset=GB2312");
if($_POST['content'])
{
$_POST["content"]=iconv("UTF-8","gb2312",$_POST["content"]);
print("內容是".$_POST['content']);
}
else
{
print("沒有內容發送");
}
?>
因而這樣可以解決亂碼問題
jsp中ajax中文亂碼
發送路徑中的參數有中文,在服務器段接收參數值是亂碼
例如:
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文件
gb2312 |
jquery ajax 獲取數據 |
gb2312 |
是 |
jsp:%@page contentType="application/json" pageEncoding="gb2312"%>這里用的json作測試,與text/html應該一樣 aps:Response.Charset="gb2312"(參照網絡未測試) php:header("Content-Type:text/html; charset=gb2312");(參照網絡未測試) html:未解決 |
gb2312 |
jquery ajax 獲取數據 |
utf-8 |
否 |
|
utf-8 |
jquery ajax 獲取數據 |
utf-8 |
否 |
|
utf-8 |
jquery ajax 獲取數據 |
gb2312 |
是 |
jsp:%@page contentType="application/json" pageEncoding="gb2312"%>這里用的json作測試,與text/html應該一樣 aps:Response.Charset="gb2312"(參照網絡未測試) php:header("Content-Type:text/html; charset=gb2312");(參照網絡未測試) html:未解決 |
您可能感興趣的文章:- ajax問題總結 比較全
- Ajax與JSON的一些學習總結
- ajax請求get與post的區別總結
- ajax 入門基礎之 XMLHttpRequest對象總結
- 關于ajax對象一些常用屬性、事件和方法大小寫比較常見的問題總結
- ajax原理總結附簡單實例及其優點
- 總結AJAX相關JS代碼片段和瀏覽器模型
- 關于Ajax技術原理的3點總結
- 使用ajax異步提交表單的幾種方法總結
- 初學者必看的Ajax總結篇