用ajax提交数据到ashx用JSON.stringify格式化参数后在服务器端取不到值?[转载至:http://q.cnblogs.com/q/34266/]

前台代码:

        $(function () {
var model = function (key) {
this.key = key;
}

var m = new model("abc");

$.ajax({
url: '/Demo.ashx',
type: 'POST',
data: JSON.stringify(m),
contentType: 'application/json; charset=utf8',
cache: false,
dataType: 'text',
success: function (data) {
alert(data);
},
error: function (xhr) {
alert("出现错误,请稍后再试:" + xhr.responseText);
}
});
});

Demo.ashx:

    public class Demo : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
context.Response.Write("Hello World" + context.Request.Form["key"]);
}

public bool IsReusable
{
get
{
return false;
}
}
}

运行后弹出 "Hello World":

改为下面这样就可以了:

$.ajax({
url: '/Demo.ashx',
type: 'POST',
//data: JSON.stringify(m),
//contentType: 'application/json; charset=utf8',
data:{key:"abc"},
cache: false,
dataType: 'text',
success: function (data) {
alert(data);
},
error: function (xhr) {
alert("出现错误,请稍后再试:" + xhr.responseText);
}
});

如图:

有人知道为什么吗?

artwl的主页 artwl | 专家六级 | 园豆:11082
提问于:2012-04-05 22:20
 
 
 
 
最佳答案
0

使用context.Request.InputStream去接看看,

 data:{key:"abc"},这个只能做个demo,大的对象你怎么写,那不搞死。
收获园豆:50
回复 | 小AI | 菜鸟二级 |园豆:223 | 2012-04-05 22:22
 

我主要是想弄明白为什么用 JSON.stringify格式化参数 取不到值

回复 | artwl | 园豆:11082 (专家六级) | 2012-04-05 22:23 |
 

context.Request.InputStream 可以取到:

 

只是不明白为什么用 context.Request.Form["key"] 取不到值

回复 | artwl | 园豆:11082 (专家六级) | 2012-04-05 22:27 |
 

@artwl: 你跟踪一下JSON.stringify(m)的结果,看看和{key:"abc"}有什么区别。去到之后你就随便玩吧,反序列化。

回复 | 小AI | 园豆:223 (菜鸟二级) | 2012-04-05 22:29 |
 

@artwl: 日,赶紧给分,强要了。。。

回复 | 小AI | 园豆:223 (菜鸟二级) | 2012-04-05 22:30 |
 

@小AI: 哈哈,行,给分

回复 | artwl | 园豆:11082 (专家六级) | 2012-04-05 22:33 |
 
 
 
 
posted @ 2012-05-10 09:24  ★★★石头★★★  阅读(3010)  评论(0编辑  收藏  举报