解決Ajax傳送中文會導致亂碼的問題
//如果傳送參數是直接賦予的,就會產生亂碼!
http_request.open("POST",url,true);
http_request.setRequestHeader('Content-Type',
'application/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-Type',
'application/x-www-form-urlencoded');
http_request.send("action="+strName+"&val="+escape(val));
//val的值為中文不會產生亂碼encodeURI(encodeURI(post)); 這樣也可以關於在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");