类型:Ajax;问题:ajax调用ashx参数获取不到;结果:ashx文件获取$.ajax()方法发送的数据

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

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

正确的写法如下:

 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,没想到就遇到了上述的问题,好在找出了问题所在并且及时解决了问题。

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

 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"]这种常规的方式是获取不到参数的,如下图所示:

郁闷了好久,怎么也想不明白为什么会这样,一开始以为是多了contentType: ‘application/json; charset=utf8‘这句代码造成的,于是把这句代码注释掉:

 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中使用如下的方式就可以获取到了,首先写一个通用的获取参数的方法,代码如下:

 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中取出传递过来的参数作处理了,完整代码如下:

 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         }

时间: 2024-10-08 08:16:20

类型:Ajax;问题:ajax调用ashx参数获取不到;结果:ashx文件获取$.ajax()方法发送的数据的相关文章

关于有继承modelDriven接口的action的ajax调用传入参数

如   Model类如下,Teacher,public class Teacher{ private Integer id: priavte  String name; private School school; } 而School, public class School{ private Integer id: priavte  String name; } 上面的Teacher,School省去了getter和setter方法. action类如下 public class Teache

ajax+ashx 完美实现input file上传文件

1.input file 样式不能满足需求 <input type="file" value="浏览" /> IE8效果图:    Firefox效果图: Chrome效果图:   2.input file上传按钮美化 css: .file{ position: relative; background-color: #b32b1b; border: 1px solid #ddd; width: 68px; height: 25px; display:

调用ajax 跨域调用接口

//ajax 跨域请求数据 function ajaxType (){ $.ajax({ url: "http://127.0.0.1:9090/spring_mvc/HttpClient/ajaxType.do?jsonpCallback=?", type: "GET", data: { pwd: encodeURI('周'), username: 'tl' }, dataType: "jsonp", success: function(dat

jQuery中Ajax事件beforesend及各参数含义

jQuery中Ajax事件beforesend及各参数含义 2014-01-21 22:27 1678人阅读 评论(0) 收藏 举报  分类: jquery(36)  转自:http://blog.sina.com.cn/s/blog_609f9fdd0100wprz.html Ajax会触发很多事件. 有两种事件,一种是局部事件,一种是全局事件: 局部事件:通过$.ajax来调用并且分配. $.ajax({ beforeSend: function(){ // Handle the befor

自己的项目结合MVC实现ajax跨域调用

好久没写东西了,自我检讨一下,写不完这篇不下班!! 最近在做一个项目模块通用的分享功能插件,由于各个模块调用所以会出现跨域问题,正好之前同事解决过,于是自己亲身实践把这次解决问题的经历记录下来.闲言少叙,书归正传~ 首先,项目背景,一个基于jquery的分享插件开发,自己也是尝试着写这么个东西,第一次写,质量肯定差,下次博文把这次开发经历写出来.由于这次解决ajax跨域的方法很简单,我就粘贴代码简单说明一下. 第一步:编写后台程序,MVC下代码如下:      //这是一个获取某个用户的通讯录分

.net使用Ajax在前台调用后台方法

/*--------前台JS代码-----------*/ var http_request; function GetAjaxObject(coaInfo) { //根据浏览器的不同来获取XMLHttpRequest对象 if (window.XMLHttpRequest) { // Mozilla, Safari, ... http_request = new XMLHttpRequest(); } else if (window.ActiveXObject) { // IE http_re

jQuery中Ajax事件顺序及各参数含义

Ajax会触发很多事件.有两种事件,一种是局部事件,一种是全局事件: 局部事件:通过$.ajax来调用并且分配. $.ajax({ beforeSend: function(){ // Handle the beforeSend event }, complete: function(){ // Handle the complete event } // ... }); 全局事件:可以用bind来绑定,用unbind来取消绑定.这个跟click/mousedown/keyup等事件类似.但他可

AJAX跨域调用相关知识-CORS和JSONP(引)

AJAX跨域调用相关知识-CORS和JSONP 1.什么是跨域 跨域问题产生的原因,是由于浏览器的安全机制,JS只能访问与所在页面同一个域(相同协议.域名.端口)的内容. 但是我们项目开发过程中,经常会遇到在一个页面的JS代码中,需要通过AJAX去访问另一个服务器并返回数据,这时候就会受到浏览器跨域的安全限制了. 这里要注意,如果只是通过AJAX向另一个服务器发送请求而不要求数据返回,是不受跨域限制的.浏览器只是限制不能访问另一个域的数据,即不能访问返回的数据,并不限制发送请求. 我们接下来就为

AJAX跨域调用ASP.NET MVC或者WebAPI服务的解决方案

问题描述 当跨域(cross domain)调用ASP.NET MVC或者ASP.NET Web API编写的服务时,会发生无法访问的情况. 重现方式 使用模板创建一个最简单的ASP.NET Web API项目,调试起来确认能正常工作 public class UserController : ApiController { public UserModel getInfo() { UserModel um = new UserModel(); um.Uid = 5; um.UserName =