欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JQuery AJAX提交中文亂碼的解決方案

 更新時(shí)間:2010年07月02日 23:45:36   作者:  
JQuery是一個(gè)非常優(yōu)秀的框架,在特定場(chǎng)合下使用JQuery提交數(shù)據(jù),相當(dāng)?shù)姆奖憧旖荨?但是,在處理一個(gè)GB2312編碼的網(wǎng)站AJAX提交時(shí),中文數(shù)據(jù)卻成了亂碼。

現(xiàn)象如下:

1)在Firefox下,處理頁面的編碼為gb2312,提交數(shù)據(jù)沒有問題,中文能夠正確解析;

2)在IE8下,處理頁面的編碼為gb2312,提交中文數(shù)據(jù)出現(xiàn)亂碼。

無論是$.post還是$.ajax,抑或$.ajaxSubmit(來自于Form插件),在之前的UTF-8編碼的網(wǎng)站都沒有出現(xiàn)過任何問題, 看來是由于提交數(shù)據(jù)的網(wǎng)頁的編碼格式造成的了。不管怎么樣,既然是瀏覽器之間存在差異,還是從HTTP包來看有什么問題吧。

打開Fiddle,分別用Firefox和IE做一個(gè)AJAX提交(以用戶登錄為例),檢查他們的HTTP頭,發(fā)現(xiàn)

1)兩個(gè)瀏覽器提交的Form數(shù)據(jù)是一致的,都是進(jìn)行了UTF-8的編碼,如下圖所示。


分析:JQuery的AJAX提交,會(huì)將要提交的數(shù)據(jù)進(jìn)行編碼,使用encodeURIComponent在js中處理數(shù)據(jù)。因此,無論是 Firefox或者IE,提交的數(shù)據(jù)都是一致的,都是UTF-8編碼后的數(shù)據(jù)。

2)查看Header,發(fā)現(xiàn)Entity中的Content-Type存在差異

在Firefox中,Content-Type指定了字符集為utf-8。


而在IE8中,卻沒有任何的字符集指定。


分析:顯然,默認(rèn)情況下,AJAX的異步提交的字符編碼應(yīng)該和網(wǎng)頁本身保持一致,也就是說,Server端在沒有發(fā)現(xiàn)顯示的charset指定的情 況下,使用gb2312來解碼數(shù)據(jù)(但是數(shù)據(jù)在提交前已經(jīng)被UTF-8編碼了),這就是為什么在IE下會(huì)出現(xiàn)亂碼的根源,而在Firefox下,瀏覽器在 提交AJAX數(shù)據(jù)的時(shí)候,加上了charset的顯示指定,導(dǎo)致Server端采用UTF-8來解碼數(shù)據(jù)(正確解碼)。

推斷:看來要解決這個(gè)中文亂碼問題,就必須給AJAX異步提交指定顯 示的charset!

馬上查閱JQuery的AJAX工具函數(shù)的說明,發(fā)現(xiàn)options中有一個(gè)指定content-type的參數(shù),給我的AJAX代碼加上:

復(fù)制代碼 代碼如下:

jQuery(form).ajaxSubmit({
url: "ajax.aspx?a=memberlogin",
type: "post",
dataType: "json",
contentType: "application/x-www-form-urlencoded; charset=utf-8",
success: showLoginResponse
});

測(cè)試,OK?。?!

相關(guān)文章

最新評(píng)論