今天在使用Jquery的ajax方法發送請求時,發如今後臺中使用ashx文件沒法接收到ajax方法中傳遞的參數,上網查了一下緣由後發現了問題所在,原來是我在$.ajax方法中指明瞭"contentType: 'application/json; charset=utf8'",因此才致使了在ashx文件中處理請求時沒法獲取傳遞到服務器端的參數,ajax
正確的寫法以下:json
1 $.ajax({ 2 url: '/Handler1.ashx?operFlag=test1', 3 type: 'POST', 4 /* 5 請求ashx文件的時候 要把contentType去掉,還有就是 6 data 格式爲 {」key」,」value」};切記 不要再 大括號外面加雙引號, 7 這樣就會在ashx頁面取不到數據而失敗 8 */ 9 //contentType: 'application/json; charset=utf8', 10 data: { 11 "key1": "xdp", 12 "key2":"孤傲蒼狼" 13 }, 14 cache: false, 15 dataType: 'text', 16 success: function (data) { 17 alert(data); 18 }, 19 error: function (xhr) { 20 alert("出現錯誤,請稍後再試:" + xhr.responseText); 21 } 22 });
這樣在ashx文件中就可使用以下的代碼來獲取$.ajax方法傳遞的參數了,代碼以下:服務器
1 string key1 = context.Request["key1"]; 2 string key2 = context.Request["key2"];
之前一直都是用$.post方法來處理ajax,因此沒有注意到這個問題,而此次因爲是項目須要,因此就使用了$.ajax,沒想到就遇到了上述的問題,好在找出了問題所在而且及時解決了問題。app
另外,最近還遇到了一個奇怪的問題,"用ajax提交數據到ashx後,用JSON.stringify格式化參數後在服務器端取不到值?",代碼以下:post
1 $.ajax({ 2 url: '/Handler1.ashx?operFlag=test2', 3 type: 'POST', 4 //JSON.stringify格式化參數 5 data: JSON.stringify({ 6 "key3": "xdp-gacl", 7 "key4": "白虎神皇" 8 }), 9 contentType: 'application/json; charset=utf8', 10 cache: false, 11 dataType: 'json', 12 success: function (data) { 13 alert(data.key3 + "|" + data.key4); 14 }, 15 error: function (xhr) { 16 alert("出現錯誤,請稍後再試:" + xhr.responseText); 17 } 18 });
結果在ashx中使用context.Request["key3"]這種常規的方式是獲取不到參數的,以下圖所示:
url
鬱悶了很久,怎麼也想不明白爲何會這樣,一開始覺得是多了contentType: 'application/json; charset=utf8'這句代碼形成的,因而把這句代碼註釋掉:spa
1 $.ajax({ 2 url: '/Handler1.ashx?operFlag=test2', 3 type: 'POST', 4 //JSON.stringify格式化參數 5 data: JSON.stringify({ 6 "key3": "xdp-gacl", 7 "key4": "白虎神皇" 8 }), 9 //contentType: 'application/json; charset=utf8', 10 cache: false, 11 dataType: 'json', 12 success: function (data) { 13 alert(data.key3 + "|" + data.key4); 14 }, 15 error: function (xhr) { 16 alert("出現錯誤,請稍後再試:" + xhr.responseText); 17 } 18 });
但是結果仍是同樣的,使用context.Request["key3"]仍是獲取不到參數,沒辦法,既然常規的方式獲取不到,那就另尋他法吧,百度了一下,找到了解決辦法,在ashx中使用以下的方式就能夠獲取到了,首先寫一個通用的獲取參數的方法,代碼以下:code
1 /// <summary> 2 /// 獲取參數 3 /// </summary> 4 /// <param name="context"></param> 5 /// <returns></returns> 6 private Dictionary<String, Object> GetParameter(HttpContext context) 7 { 8 StreamReader reader = new StreamReader(context.Request.InputStream); 9 //獲得json字符串:strJson={"key3":"xdp-gacl","key4":"白虎神皇"} 10 String strJson = HttpUtility.UrlDecode(reader.ReadToEnd()); 11 JavaScriptSerializer jss = new JavaScriptSerializer(); 12 //將json字符串反序列化成一個Dictionary對象 13 Dictionary<String, Object> dicParameter = jss.Deserialize<Dictionary<String, Object>>(strJson); 14 return dicParameter; 15 }
GetParameter方法返回一個dicParameter對象,dicParameter就存放了從$.ajax方法中提交到ashx中的參數,以下圖所示:
對象
這樣就能夠從dicParameter中取出傳遞過來的參數做處理了,完整代碼以下:blog
1 public void ProcessRequest(HttpContext context) 2 { 3 context.Response.ContentType = "text/plain"; 4 string operFlag = context.Request["operFlag"]; 5 if (operFlag == "test1") 6 { 7 string key1 = context.Request["key1"]; 8 string key2 = context.Request["key2"]; 9 string resStr = key1 + "|" + key2; 10 context.Response.Write(resStr); 11 } 12 else if (operFlag == "test2") 13 { 14 Dictionary<String, Object> dicParameter = GetParameter(context); 15 string key3 = dicParameter["key3"].ToString(); 16 string key4 = dicParameter["key4"].ToString(); 17 string resStr = "{\"key3\":\"" + key3 + "\", \"key4\":\"" + key4 + "\"}"; 18 context.Response.Write(resStr); 19 } 20 21 }