淺析AJAX亂碼及錯誤解決方案_AJAX相關

來源:互聯網
上載者:User

一類是出現亂碼,另外一類是出現javascript系統錯誤:-1072896658的。提示在XX.innerHTML=xmlhttp.responseText;這行。
其實都是因為編碼不統一引起的。解決方案就是加入指定字元編碼指令。

一、什麼是字元編碼
定義見:http://zh.wikipedia.org/wiki/%E5%AD%97%E7%AC%A6%E7%BC%96%E7%A0%81。
通俗的講:你看到的“我”是一張小圖片,每個漢字都是,他對應一個編碼4650,這些圖片都存放在一個叫做字型檔的地方,你在字型檔中找到4650號圖片,就是“我”了,其實字型檔就是windows的字型,宋體字型檔、雅黑字型檔等等等,一篇文章,你可以用宋體、仿宋體,不論用那種,“我”的對應的編碼是不變的。你可以換字型,顯示出來的“我”字型不同,但是還是一個“我”字。

二、問題的產生。
編碼就有編碼格式因此就產生了各種編碼,漢字典型的有GB2312簡體的,BIG5繁體的,Unicode繁簡都有的。這裡就產生問題了,在GB2312中4650是“我”,在Unicode中是6211。4650在Unicode中對應的是“䙐”。
因此,你在伺服器的asp,jsp中用GB2312編碼發送了“我”,到了瀏覽器,瀏覽器以為是Unicode,翻譯出來就是“䙐”。這就是亂碼了。
注意:本文中的Unicode僅以UTF-8為例。UTF-8定義傳送門:http://zh.wikipedia.org/zh/UTF-8

三、解決思路。
當中還要注意一點:據不可靠訊息JavaScript是用Unicode UTF-8作為內碼的。
因此,如果使用Ajax,最好呈現頁面也指定編碼為UTF-8,省的轉換了。統一了編碼,自然就沒有了亂碼。

四、具體方法。
對於服務端指令碼,在指令碼開頭:
PHP:header('Content-Type:text/html;charset=UTF-8');
ASP:Response.Charset="UTF-8"
JSP:response.setHeader("Charset","UTF-8");
注意ASP,很多地方是Response.Charset("UTF-8"),這是不正確的,Charset是屬性不是方法,誤導了很多人。
對於HTML

複製代碼 代碼如下:

<head>
<meta name="description" content="Free Web tutorials" />
<meta name="keywords" content="HTML,CSS,XML,JavaScript" />
<meta name="author" content="Hege Refsnes" />
<meta http-equiv="content-type" content="text/html;charset=UTF-8" />
</head>

charset=編碼名稱。
對於<script>
<scripte type="text/javascript" charset="UTF-8">
但是,在實際應用中,特別是頁面轉換時,會出現前一個頁面是UTF-8的,後面頁面突然跳到了GB2312,然後亂碼了,怎麼辦?
在伺服器asp(PHP,JSP自行查方法)指令碼開頭中寫入
Session.CodePage=65001
保持在這個Session中一直是UTF-8。
如果你想統一成GB2312,那麼記得把上面的UTF-8換成GB2312,65001換成936。
這三部完成,基本可以解決亂碼問題。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.