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 }

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

  1. php 腾讯云 对象存储V5版本 获取返回的上传文件的链接方法

    腾讯云 对象存储V5版本 文档地址:https://github.com/tencentyun/cos-php-sdk-v5 调用简单文件上传方法: 返回数据如下 Array ( [data:prot ...

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

    今天在使用Jquery的ajax方法发送请求时,发现在后台中使用ashx文件无法接收到ajax方法中传递的参数,上网查了一下原因后发现了问题所在,原来是我在$.ajax方法中指明了"cont ...

  3. SqlParameter设定的value值为0时、调用的存储过程获取到的值却为null解决方法

    原C#代码如下: if (query != null) { switch (query.MethodFlag) { //进出口退补税额统计表 case (int)EnumClassifyCorrect ...

  4. ajax方法参数详解与$.each()和jquery里面each方法的区别

    JQuery中$.ajax()方法参数详解 url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为g ...

  5. 类型:JQuery;问题:ajax调用ashx文件;结果:ashx文件怎么获取$.ajax()方法发送的json数据

    ashx文件怎么获取$.ajax()方法发送的json数据 作者:careful 和ajax相关     新浪微博QQ空间QQ微博百度搜藏腾讯朋友QQ收藏百度空间人人网开心网0 $.ajax({  t ...

  6. jQuery $.ajax 参数说明及调用注意事项

    $.ajax参数设置 备注:data.contentType.dataType属性值很重要!!! async 类型:Boolean 默认值: true.默认设置下,所有请求均为异步请求.如果需要发送同 ...

  7. 用JQuery中的Ajax方法获取web service等后台程序中的方法

    用JQuery中的Ajax方法获取web service等后台程序中的方法 1.准备需要被前台html页面调用的web Service,这里我们就用ws来代替了,代码如下: using System; ...

  8. Asp.Net MVC WebAPI的创建与前台Jquery ajax后台HttpClient调用详解

    1.什么是WebApi,它有什么用途? Web API是一个比较宽泛的概念.这里我们提到Web API特指ASP.NET MVC Web API.在新出的MVC中,增加了WebAPI,用于提供REST ...

  9. jquery Ajax跨域调用WebServices方法

    由于公司需要开发一个手机页面,想提供给同事直接在手机上可以查询SAP资料.数据需要使用js调用webserver来获取. 因为初次使用Jquery调用Webserver,所以期间并不顺利.测试调用We ...

随机推荐

  1. Codeforces Round #374 (Div. 2) A , B , C 水,水,拓扑dp

    A. One-dimensional Japanese Crossword time limit per test 1 second memory limit per test 256 megabyt ...

  2. php开发工程师面必问题

    随着培训机构的增加,越来越多的php从业者流入市场,从而影响了php就业环境.公司对人才的要求越来越高,而技术者本身也要技术过硬,学习越来越多的东西,因为只有这样,你才能跑在别人前面,才不被市场抛弃, ...

  3. python 换行

    python3 end = “”:输入参数不换行. 就是打印之后不换行. python字符串换行: (1)三个单引号,例如print '''我是程序员 刚学习python''' (2)三个双引号,例如 ...

  4. SVN中如何为文件夹中的所有文件加锁

    经过一段时间的试用,发现不加锁的共享式开发还是不太方便.还是全部设置为独占式加锁,如有共享式修改需求再设置为不加锁比较好. 经过一番摸索,总结出如下的加锁方式是可行的: 注:第一步是必须的,必须完成第 ...

  5. 用node.js可以开启静态服务 不需要借助apache 或者xampl

    安装好了Node以及express,然后用express命令生成express架构, 目录结构下面有一个public页面, 把你的静态页面放到这个文件夹下, 通过npm start,开启服务就可以在浏 ...

  6. Ajax与后台的交互

    Ajax Java 交互 jsp代码 <%@ page language="java" import="java.util.*" pageEncoding ...

  7. Kattis - redblacktree Red Black Tree (树形背包)

    问题:有一课含有n(n<=2e5)个结点的数,有m(m<=1000)个结点是红色的,其余的结点是黑色的.现从树中选若干数量的结点,其中红色的恰有k个,并且每个结点都不是其他任何另一个结点的 ...

  8. mysql_union all 纵向合并建表_20170123

    年前事情比较多,博客不能每天更新了. 1.union all 纵向建表和left join 横向建表的数据结构区别 先贴代码 后面再补充 (#销售确认额 SELECT '05收货销售额' AS 标识, ...

  9. 洛谷 P3223 [HNOI2012]排队

    题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...

  10. mysql 多表查询 左联 去重方法

    1.数据库中的两张表: 2.传统左联查询数据结果如下: 3.替换查询语句可得到去重数据结果: