解決AJAX傳送中文會導致亂碼的問題

//如果傳送參數是直接賦予的,就會產生亂碼!
http_request.open("POST",url,true); 
http_request.setRequestHeader(
Content-Typeapplication/x-www-form-urlencoded); 
http_request.send(
"action="+strName+"&val="+val);   //如果val的值為中文,則產生亂碼

//解決方法很簡單:使用javascript中的escape(string) 函數
http_request.open("POST",url,true); 
http_request.setRequestHeader(
Content-Typeapplication/x-www-form-urlencoded); 
http_request.send(
"action="+strName+"&val="+escape(val));   //val的值為中文不會產生亂碼

關于在AJAX中GET回的ResponseText中文亂碼的最簡解決辦法
 

用AJAX 來GET回一個頁面時,RESPONSETEXT里面的中文多半會出現亂碼,這是因為xmlhttp在處理返回的responseText的時候,是把 resposeBody按UTF-8編碼進解碼考形成的,如果服務器送出的確實是UTF-8的數據流的時候漢字會正確顯示,而送出了GBK編碼流的時候就 亂了。解決的辦法就是在送出的流里面加一個HEADER,指明送出的是什么編碼流,這樣XMLHTTP就不會亂搞了。

PHP:header(’Content-Type:text/html;charset=GB2312′);
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");