ashx文件获取$.ajax()方法发送的数据
来源: 阅读:822 次 日期:2016-06-20 17:04:19
温馨提示: 小编为您整理了“ashx文件获取$.ajax()方法发送的数据”,方便广大网友查阅!

这篇文章主要介绍了ashx文件获取$.ajax()方法发送的数据的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下

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

正确的写法如下:

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

string key = context.Request["key"];

string key = context.Request["key"];

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

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

$.ajax({

url: '/Handler.ashx?operFlag=test',

type: 'POST',

//JSON.stringify格式化参数

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("出现错误,请稍后再试:" + xhr.responseText);

}

});

结果在ashx中使用context.Request["key3"]这种常规的方式是获取不到参数的,如下图所示:

名单

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

$.ajax({

url: '/Handler.ashx?operFlag=test',

type: 'POST',

//JSON.stringify格式化参数

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("出现错误,请稍后再试:" + xhr.responseText);

}

});

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

/// <summary>

/// 获取参数

/// </summary>

/// <param name="context"></param>

/// <returns></returns>

private Dictionary<String, Object> 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<String, Object> dicParameter = jss.Deserialize<Dictionary<String, Object>>(strJson);

return dicParameter;

}

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

名单

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

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()方法发送的数据,希望对大家有所帮助

更多信息请查看网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map