ashx文件獲取$.ajax()方法發(fā)送的數(shù)據(jù)
今天在使用Jquery的ajax方法發(fā)送請(qǐng)求時(shí),發(fā)現(xiàn)在后臺(tái)中使用ashx文件無(wú)法接收到ajax方法中傳遞的參數(shù),上網(wǎng)查了一下原因后發(fā)現(xiàn)了問(wèn)題所在,原來(lái)是我在$.ajax方法中指明了"contentType: 'application/json; charset=utf8'",所以才導(dǎo)致了在ashx文件中處理請(qǐng)求時(shí)無(wú)法獲取傳遞到服務(wù)器端的參數(shù),
正確的寫(xiě)法如下:
$.ajax({ url: '/Handler.ashx?operFlag=test', type: 'POST', /* 請(qǐng)求ashx文件的時(shí)候 要把contentType去掉,還有就是 data 格式為 {”key”,”value”};切記 不要再 大括號(hào)外面加雙引號(hào), 這樣就會(huì)在ashx頁(yè)面取不到數(shù)據(jù)而失敗 */ //contentType: 'application/json; charset=utf', data: { "key": "xdp", "key":"孤傲蒼狼" }, cache: false, dataType: 'text', success: function (data) { alert(data); }, error: function (xhr) { alert("出現(xiàn)錯(cuò)誤,請(qǐng)稍后再試:" + xhr.responseText); } });
這樣在ashx文件中就可以使用如下的代碼來(lái)獲取$.ajax方法傳遞的參數(shù)了,代碼如下:
string key = context.Request["key"]; string key = context.Request["key"];
以前一直都是用$.post方法來(lái)處理ajax,所以沒(méi)有注意到這個(gè)問(wèn)題,而這次由于是項(xiàng)目需要,所以就使用了$.ajax,沒(méi)想到就遇到了上述的問(wèn)題,好在找出了問(wèn)題所在并且及時(shí)解決了問(wèn)題。
另外,最近還遇到了一個(gè)奇怪的問(wèn)題,"用ajax提交數(shù)據(jù)到ashx后,用JSON.stringify格式化參數(shù)后在服務(wù)器端取不到值?",代碼如下:
$.ajax({ url: '/Handler.ashx?operFlag=test', type: 'POST', //JSON.stringify格式化參數(shù) 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("出現(xiàn)錯(cuò)誤,請(qǐng)稍后再試:" + xhr.responseText); } });
結(jié)果在ashx中使用context.Request["key3"]這種常規(guī)的方式是獲取不到參數(shù)的,如下圖所示:
郁悶了好久,怎么也想不明白為什么會(huì)這樣,一開(kāi)始以為是多了contentType: 'application/json; charset=utf8'這句代碼造成的,于是把這句代碼注釋掉:
$.ajax({ url: '/Handler.ashx?operFlag=test', type: 'POST', //JSON.stringify格式化參數(shù) 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("出現(xiàn)錯(cuò)誤,請(qǐng)稍后再試:" + xhr.responseText); } });
可是結(jié)果還是一樣的,使用context.Request["key3"]還是獲取不到參數(shù),沒(méi)辦法,既然常規(guī)的方式獲取不到,那就另尋他法吧,百度了一下,找到了解決辦法,在ashx中使用如下的方式就可以獲取到了,首先寫(xiě)一個(gè)通用的獲取參數(shù)的方法,代碼如下:
/// <summary> /// 獲取參數(shù) /// </summary> /// <param name="context"></param> /// <returns></returns> private Dictionary<String, Object> GetParameter(HttpContext context) { StreamReader reader = new StreamReader(context.Request.InputStream); //得到j(luò)son字符串:strJson={"key":"xdp-gacl","key":"白虎神皇"} String strJson = HttpUtility.UrlDecode(reader.ReadToEnd()); JavaScriptSerializer jss = new JavaScriptSerializer(); //將json字符串反序列化成一個(gè)Dictionary對(duì)象 Dictionary<String, Object> dicParameter = jss.Deserialize<Dictionary<String, Object>>(strJson); return dicParameter; }
GetParameter方法返回一個(gè)dicParameter對(duì)象,dicParameter就存放了從$.ajax方法中提交到ashx中的參數(shù),如下圖所示:
這樣就可以從dicParameter中取出傳遞過(guò)來(lái)的參數(shù)作處理了,完整代碼如下:
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()方法發(fā)送的數(shù)據(jù),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
jQuery獲取父元素節(jié)點(diǎn)、子元素節(jié)點(diǎn)及兄弟元素節(jié)點(diǎn)的方法
這篇文章主要介紹了jQuery獲取父元素節(jié)點(diǎn)、子元素節(jié)點(diǎn)及兄弟元素節(jié)點(diǎn)的方法,結(jié)合實(shí)例形式總結(jié)分析了jQuery節(jié)點(diǎn)操作的相關(guān)技巧,需要的朋友可以參考下2016-04-04JQuery Ajax動(dòng)態(tài)加載Table數(shù)據(jù)的實(shí)例講解
今天小編就為大家分享一篇JQuery Ajax動(dòng)態(tài)加載Table數(shù)據(jù)的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08基于JQuery的簡(jiǎn)單實(shí)現(xiàn)折疊菜單代碼
利用JQUERY簡(jiǎn)單的實(shí)現(xiàn)功能菜單的折疊效果。本人初學(xué),寫(xiě)后臺(tái)稍多一點(diǎn),很少寫(xiě)前臺(tái)的效果。還請(qǐng)大蝦們多多指教。2010-09-09jQuery實(shí)現(xiàn)網(wǎng)頁(yè)拼圖游戲
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)網(wǎng)頁(yè)拼圖游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11jQuery實(shí)現(xiàn)單擊按鈕遮罩彈出對(duì)話框效果(1)
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)單擊按鈕遮罩彈出對(duì)話框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02jquery的ajax和getJson跨域獲取json數(shù)據(jù)的實(shí)現(xiàn)方法
本篇文章主要是對(duì)jquery的ajax和getJson跨域獲取json數(shù)據(jù)的實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-02-02jQuery簡(jiǎn)單設(shè)置文本框回車(chē)事件的方法
這篇文章主要介紹了jQuery簡(jiǎn)單設(shè)置文本框回車(chē)事件的方法,涉及jQuery簡(jiǎn)單事件綁定與響應(yīng)操作相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08jQuery ajax全局函數(shù)處理session過(guò)期后的ajax跳轉(zhuǎn)問(wèn)題
這篇文章主要介紹了基于jQuery的全局ajax函數(shù)處理session過(guò)期后的ajax操作的相關(guān)資料,需要的朋友可以參考下2016-06-06jQuery中的ready函數(shù)與window.onload誰(shuí)先執(zhí)行
這篇文章主要介紹了jquery中ready函數(shù)與window.onload函數(shù)的區(qū)別,別講解了他們各自執(zhí)行的時(shí)機(jī),通俗易懂,需要的朋友可以參考下。2016-06-06