在使用AJAX傳數據的時候我們經常會遇到亂碼問題,由于XMLHTTP采用的是Unicode編碼上傳數據,因此就很容易出現中文亂碼的情況,那么我們現在就去看看ajax中文亂碼的解決方法總結。
有一種解決辦法就是使用encodeURIComponent加上修改 Content-Type 為 application/x-www-form-urlencoded" 來把數據統一編碼成 url 格式,當然,也可以指定編碼,如:“application/x-www-form-urlencoded; charset=utf-8 ”,
解決方法之一
例子:
?
解決方法之二
就是在PHP文件中顯示聲明為GB2312
?
?
?
而對于發送到服務器的中文進行轉碼.
如下
?
?
因而這樣可以解決亂碼問題
jsp中ajax中文亂碼
發送路徑中的參數有中文,在服務器段接收參數值是亂碼
例如:
var url="a.jsp?name=小李";
xmlHTTP.open ("post",url,true);
解決辦法:
利用javascript的提供的escape()或encodeURI()方法
例如:
客戶端:
?
?
也有人寫成var url="a.jsp?name=escape("小李")";
功能和encodeURI方法類似。
?
?
服務器端:
?
?
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中文亂碼的解決方法總結,當大家遇到此類問題的時候就可以根據小編介紹的方法去進行解決哦,希望對大家有所幫助。
新聞熱點
疑難解答
圖片精選