ajax post data 獲取不到數據,注意 content-type的設置 、post/get
關於 jQuery data 傳遞數據。網上各種獲取不到數據,亂碼之類的。
好吧今天我也遇到了,網上一查各種糾結。亂碼不管先看獲取不到數據。
因爲之前一直用jQuery ajax get的方式傳遞參數, 默認沒有設置過 contentType 的值。
var Skip = 49; //Number of skipped row
var Take = 14; //
function Load(Skip, Take) {
$('#divPostsLoader').html('');
//send a query to server side to present new content
$.ajax({
type: "get",
url: "AjaxImage.ashx",
data: { Skip: Skip, Take: Take },
//contentType: "application/json; charset=utf-8",//(可以)
//contentType: "text/xml",//(可以)
//contentType:"application/x-www-form-urlencoded",//(可以)
//dataType: "string",
success: function (data) {
if (data != "") {
$('.thumb').append(data);
}
$('#divPostsLoader').empty();
}
})
};
chrome下,沒有設置contentType的值,好,我們來看默認情況:
默認參數通過url參數傳遞,請求的內容類型:application/x-www-form-urlencoded
一般處理文件獲取參數內容:
int Skip = Convert.ToInt32(context.Request["Skip"]); 2: int Take = Convert.ToInt32(context.Request["Take"]);
毫無壓力,因爲我一直都是這麼幹的大笑,沒有任何問題。好了,來換一下請求的內容類型:
//contentType: "application/json; charset=utf-8",//(可以) 2: //contentType: "text/xml",//(可以)
也都可以,參數獲取正常。
這也就是我們說的get方式,參數是跟在url後邊,與Content-Type無關。
可是今天要用post方式了有木有。
$.ajax({ 2: type: "post",
chrome下,沒有設置contentType的值,來看默認情況:
<img width="244" border="0" height="168" alt="image" src="http://img2.shangxueba.com/img/alixixi/20140806/15/328E5D53B584D08EB4362DC1F3F1F8B1.png" title="image" style="background-image: none; padding-top: 0px; padding-left: 0px; margin: 0px; display: inline; padding-right: 0px; border-width: 0px;" nload="return imgzoom(this,600);" nclick="javascript.:window.open(this.src);" style="cursor:pointer;"/>
data數據由from表單提交,請求的內容類型:application/x-www-form-urlencoded,
好了,默認情況下一般處理文件獲取參數也可以。
可是,但是 我最開始設置的是 contentType: "application/json; charset=utf-8",看圖:
Request Paload 是什麼???
調試一下,看我們的from裏邊,沒有內容:
好吧, 到這裏我們解決了 博問裏那個問題(http://q.cnblogs.com/q/11342/),
本來搜索到這個博問,甚是高興的,但是,懸而未決有木有,小夥伴不厚道啊!捧腹大笑
經測試:
//contentType: "application/json; charset=utf-8",//(不可以)
//contentType: "text/xml",//(不可以)
contentType:"application/x-www-form-urlencoded",//(可以)
總結一下吧:本來get/post方式都是知道的,但注意,contentType與傳遞數據匹配(本文data)。
做過模擬登錄、模擬提交數據的同學肯定都很清楚了。