成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? ashx文件獲取$.ajax()方法發送的數據
全站頭部文字 我要出現在這里
ashx文件獲取$.ajax()方法發送的數據 676 2024-03-02   

今天在使用Jquery的ajax方法發送請求時,發現在后臺中使用ashx文件無法接收到ajax方法中傳遞的參數,上網查了一下原因后發現了問題所在,原來是我在$.ajax方法中指明了"contentType: 'application/json; charset=utf8'",所以才導致了在ashx文件中處理請求時無法獲取傳遞到服務器端的參數,

正確的寫法如下:

$.ajax({
url: '/Handler.ashx?operFlag=test',
type: 'POST',
/*
請求ashx文件的時候 要把contentType去掉,還有就是
data 格式為 {”key”,”value”};切記 不要再 大括號外面加雙引號,
這樣就會在ashx頁面取不到數據而失敗
*/
//contentType: 'application/json; charset=utf',
data: {
"key": "xdp",
"key":"孤傲蒼狼" 
},
cache: false,
dataType: 'text',
success: function (data) {
alert(data);
},
error: function (xhr) {
alert("出現錯誤,請稍后再試:" + xhr.responseText);
}
}); 

這樣在ashx文件中就可以使用如下的代碼來獲取$.ajax方法傳遞的參數了,代碼如下:

string key = context.Request["key"];
string key = context.Request["key"]; 

以前一直都是用$.post方法來處理ajax,所以沒有注意到這個問題,而這次由于是項目需要,所以就使用了$.ajax,沒想到就遇到了上述的問題,好在找出了問題所在并且及時解決了問題。

另外,最近還遇到了一個奇怪的問題,"用ajax提交數據到ashx后,用JSON.stringify格式化參數后在服務器端取不到值?",代碼如下:

$.ajax({
url: '/Handler.ashx?operFlag=test',
type: 'POST',
//JSON.stringify格式化參數
data: JSON.stringify({
"key": "xdp-gacl",
"key": "白虎神皇"
}),
contentType: 'application/json; charset=utf',
cache: false,
dataType: 'json',
success: function (data) {
alert(data.key + "|" + data.key);
},
error: function (xhr) {
alert("出現錯誤,請稍后再試:" + xhr.responseText);
}
}); 

結果在ashx中使用context.Request["key3"]這種常規的方式是獲取不到參數的,如下圖所示:

查看圖片

郁悶了好久,怎么也想不明白為什么會這樣,一開始以為是多了contentType: 'application/json; charset=utf8'這句代碼造成的,于是把這句代碼注釋掉:

$.ajax({
url: '/Handler.ashx?operFlag=test',
type: 'POST',
//JSON.stringify格式化參數
data: JSON.stringify({
"key": "xdp-gacl",
"key": "白虎神皇"
}),
//contentType: 'application/json; charset=utf',
cache: false,
dataType: 'json',
success: function (data) {
alert(data.key + "|" + data.key);
},
error: function (xhr) {
alert("出現錯誤,請稍后再試:" + xhr.responseText);
}
}); 

可是結果還是一樣的,使用context.Request["key3"]還是獲取不到參數,沒辦法,既然常規的方式獲取不到,那就另尋他法吧,百度了一下,找到了解決辦法,在ashx中使用如下的方式就可以獲取到了,首先寫一個通用的獲取參數的方法,代碼如下:

/// <summary>
/// 獲取參數
/// </summary>
/// <param name="context"></param>
/// <returns></returns>
private Dictionary<String, Object> GetParameter(HttpContext context)
{
StreamReader reader = new StreamReader(context.Request.InputStream);
//得到json字符串:strJson={"key":"xdp-gacl","key":"白虎神皇"}
String strJson = HttpUtility.UrlDecode(reader.ReadToEnd());
JavaScriptSerializer jss = new JavaScriptSerializer();
//將json字符串反序列化成一個Dictionary對象
Dictionary<String, Object> dicParameter = jss.Deserialize<Dictionary<String, Object>>(strJson);
return dicParameter;
} 

GetParameter方法返回一個dicParameter對象,dicParameter就存放了從$.ajax方法中提交到ashx中的參數,如下圖所示:

查看圖片

這樣就可以從dicParameter中取出傳遞過來的參數作處理了,完整代碼如下:

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string operFlag = context.Request["operFlag"];
if (operFlag == "test")
{
string key = context.Request["key"];
string key = context.Request["key"];
string resStr = key + "|" + key;
context.Response.Write(resStr);
}
else if (operFlag == "test")
{
Dictionary<String, Object> dicParameter = GetParameter(context);
string key = dicParameter["key"].ToString();
string key = dicParameter["key"].ToString();
string resStr = "{"key":"" + key + "", "key":"" + key + ""}";
context.Response.Write(resStr);
}
}

以上所述是小編給大家介紹的ashx文件獲取$.ajax()方法發送的數據,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對綠夏網網站的支持!



主站蜘蛛池模板: 二年级最佳家长评语| 韧战作文800字初中| 建设工程档案归档整理规范| 送教上门工作情况记录表| lebron james音标| 黄明昊身高| 《最后的凶手》免费观看| 回术人生的重来人生| 一人之下动画| 速度与激情10什么时候上映的| 寇世勋个人资料简介| 吸油记游戏破解版无限金币| 黑势力| 杨幂的视频| 破天荒| 湖北影视| 二胡独奏北国之春| 菠萝菠萝蜜视频在线免费观看| va在线观看视频| 企鹅头像| 斧头(俄罗斯电影) 战争片| 新爱情乐园| 七品芝麻官豫剧| derpixon动画在线观看| 百家讲坛《两宋风云》| 五年级上册写字表拼音| 看美女图片| 徐童| 山西电视台今天电视节目表| 白雪公主和七个小矮人电影| 手游传奇排行榜第一名| ?1,| 开国大典ppt课件| free xxx 性欧美| 李道新| 黄土高坡歌词| 孙婉| 绅士联盟| 混凝土结构施工质量验收规范gb50204-2015 | 变成黑皮辣妹然后和朋友做| 库存管理软件|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103