微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ashx文件获取$.ajax()方法发送的数据

今天在使用Jquery的ajax方法发送请求时,发现在后台中使用ashx文件无法接收到ajax方法中传递的参数,上网查了一下原因后发现了问题所在,原来是我在$.ajax方法中指明了"contentType: 'application/json; charset=utf8'",所以才导致了在ashx文件中处理请求时无法获取传递到服务器端的参数,

正确的写法如下:

rush:js;"> $.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方法传递的参数了,代码如下:

rush:js;"> string key = context.Request["key"]; string key = context.Request["key"];

以前一直都是用$.post方法来处理ajax,所以没有注意到这个问题,而这次由于是项目需要,所以就使用了$.ajax,没想到就遇到了上述的问题,好在找出了问题所在并且及时解决了问题。

另外,最近还遇到了一个奇怪的问题,"用ajax提交数据到ashx后,用JSON.stringify格式化参数后在服务器端取不到值?",代码如下:

rush:js;"> $.ajax({ url: '/Handler.ashx?operFlag=test',//JSON.stringify格式化参数 data: JSON.stringify({ "key": "xdp-gacl","key": "白虎神皇" }),contentType: 'application/json; charset=utf',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'这句代码造成的,于是把这句代码注释掉:

rush:js;"> $.ajax({ url: '/Handler.ashx?operFlag=test',//contentType: 'application/json; charset=utf',error: function (xhr) { alert("出现错误,请稍后再试:" + xhr.responseText); } });

可是结果还是一样的,使用context.Request["key3"]还是获取不到参数,没办法,既然常规的方式获取不到,那就另寻他法吧,百度了一下,找到了解决办法,在ashx中使用如下的方式就可以获取到了,首先写一个通用的获取参数的方法代码如下:

rush:js;"> /// /// 获取参数 /// /// aram name="context"> /// private Dictionary 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 dicParameter = jss.Deserialize>(strjson); return dicParameter; }

GetParameter方法返回一个dicParameter对象,dicParameter就存放了从$.ajax方法中提交到ashx中的参数,如下图所示:

这样就可以从dicParameter中取出传递过来的参数作处理了,完整代码如下:

rush:js;"> 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 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()方法发送的数据。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

原文地址:https://www.jb51.cc/ajax/48423.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐