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


Posted in Javascript onMay 26, 2016

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

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

郁闷了好久,怎么也想不明白为什么会这样,一开始以为是多了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中的参数,如下图所示:

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

这样就可以从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()方法发送的数据,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript 函数及作用域总结介绍
Nov 12 Javascript
JQuery CheckBox(复选框)操作方法汇总
Apr 15 Javascript
非常棒的jQuery图片轮播效果
Apr 17 Javascript
Node.js检测端口(port)是否被占用的简单示例
Sep 29 Javascript
Jquery和Js获得元素标签名称的方法总结
Oct 08 Javascript
VUE元素的隐藏和显示(v-show指令)
Jun 23 Javascript
原生js获取left值和top值的三种方法
Aug 02 Javascript
Angular中响应式表单的三种更新值方法详析
Aug 22 Javascript
详解EasyUi控件中的Datagrid
Aug 23 Javascript
mongoose更新对象的两种方法示例比较
Dec 19 Javascript
js实现ajax的用户简单登入功能
Jun 18 Javascript
JS typeof fn === 'function' &amp;&amp; fn()详解
Aug 22 Javascript
js操作数据库实现注册和登陆的简单实例
May 26 #Javascript
js判断主流浏览器类型和版本号的简单实现代码
May 26 #Javascript
轻松掌握JavaScript中的Math object数学对象
May 26 #Javascript
JS表格组件神器bootstrap table详解(强化版)
May 26 #Javascript
JS在一定时间内跳转页面及各种刷新页面的实现方法
May 26 #Javascript
JavaScript的String字符串对象常用操作总结
May 26 #Javascript
jquery.form.js框架实现文件上传功能案例解析(springmvc)
May 26 #Javascript
You might like
php中定义网站根目录的常用方法
2010/08/08 PHP
php使用unset()删除数组中某个单元(键)的方法
2015/02/17 PHP
php通过baihui网API实现读取word文档并展示
2015/06/22 PHP
php 实现进制相互转换
2016/04/07 PHP
php-app开发接口加密详解
2018/04/18 PHP
php简单检测404页面的方法示例
2019/08/23 PHP
JQuery操作三大控件(下拉,单选,复选)的方法
2013/08/06 Javascript
js判断页面中是否有指定控件的简单实例
2014/03/04 Javascript
JS兼容浏览器的导出Excel(CSV)文件的方法
2014/05/03 Javascript
javascript页面倒计时实例
2015/07/25 Javascript
详解angularjs中如何实现控制器和指令之间交互
2017/05/31 Javascript
关于vue.extend和vue.component的区别浅析
2017/08/16 Javascript
利用百度地图API获取当前位置信息的实例
2017/11/06 Javascript
Angular2学习笔记之数据绑定的示例代码
2018/01/03 Javascript
利用Decorator如何控制Koa路由详解
2018/06/26 Javascript
微信小程序webview与h5通过postMessage实现实时通讯的实现
2019/08/20 Javascript
在vue中使用Echarts利用watch做动态数据渲染操作
2020/07/20 Javascript
微信小程序通过websocket实时语音识别的实现代码
2020/08/19 Javascript
[02:17]2016完美“圣”典风云人物:Sccc专访
2016/12/03 DOTA
分析用Python脚本关闭文件操作的机制
2015/06/28 Python
Python while 循环使用的简单实例
2016/06/08 Python
详解Python中类的定义与使用
2017/04/11 Python
PyQt 线程类 QThread使用详解
2017/07/16 Python
终端命令查看TensorFlow版本号及路径的方法
2018/06/13 Python
Python使用matplotlib绘制三维参数曲线操作示例
2019/09/10 Python
Python解析json代码实例解析
2019/11/25 Python
Python代码生成视频的缩略图的实例讲解
2019/12/22 Python
opencv python在视屏上截图功能的实现
2020/03/05 Python
Python selenium爬取微信公众号文章代码详解
2020/08/12 Python
FC-Moto西班牙:摩托车手最大的购物场所之一
2019/04/11 全球购物
解释一下ruby中的特殊方法与特殊类
2013/02/26 面试题
文明宿舍获奖感言
2014/02/07 职场文书
物流业务员岗位职责
2014/02/08 职场文书
市场营销毕业生自荐信范文
2014/04/01 职场文书
教师节学生演讲稿
2014/09/03 职场文书
智慧人生:永远不需要向任何人解释你自己
2019/08/20 职场文书