【发布时间】:2010-12-05 10:38:39
【问题描述】:
我正在将数据发布到 MVC 控制器,并且我正在尝试维护状态以及乐观并发。我目前正在发回一个 JSON 请求,但是否愿意接受可行的替代方案?
我已经使用以下命令发布名称/值集合:
$.ajax({
url: g_appPath + "/Rounding.aspx/Round/" + $("#OfferId").val(),
type: 'POST',
dataType: 'html',
data: $.toJSON(data), // <-- data = name/value array
contentType: 'application/json; charset=utf-8',
beforeSend: doSubmitBeforeSend,
complete: doSubmitComplete,
success: doSubmitSuccess
});
我还有一个(加密的)id 和时间戳数组,我想传回它们,以便服务器可以对其进行解密,然后在保存数据之前验证数据是否仍然新鲜。
数据对象是独立的并且不是其中一个或另一个的子对象或包装器数组中的子对象(因为服务器端的反射反序列化)是非常重要的。还需要注意的是,我希望异步执行此操作,并且不作为表单提交。
我的问题是:有什么方法可以使用 'application/json' 作为内容类型回发 2 个 JSON 对象?
我的另一个问题是:有没有更好/另一种方法可以做到这一点?
提前致谢!
更新:我解决了我的问题,将 contentType 参数更改为默认值,而是将字符串化的 ajax 数据作为单独的命名参数发送到查询字符串中。
当你使用 contentType: 'application/json; charset=utf-8',这会将数据推送到请求的正文中,而不是查询字符串。我的新 $.ajax() 帖子现在看起来像这样:
$.ajax({
url: g_appPath + "/Rounding.aspx/Round/" + $("#OfferId").val(),
type: 'POST',
dataType: 'html',
data: "RoundingData=" + $.toJSON(data) + "&StateData=" + $.toJSON(stateData),
// --removed! contentType: 'application/json; charset=utf-8',
beforeSend: doSubmitBeforeSend,
complete: doSubmitComplete,
success: doSubmitSuccess
});
这个问题确实是因为我对这种类型的数据操作缺乏经验,我希望将来寻找这个的人可能会偶然发现这个。
谢谢!
丹
【问题讨论】:
-
感谢您的反馈!我非常感谢您为帮助我解决这个问题所做的努力。我的目标之一是避免将数据放在包装器数组中,我认为这可能是唯一可以使用内容类型“application/json;”的方法。字符集=utf-8'。我已经制定了一个解决方案,我将把它作为我的问题的附录发布。
-
仅供参考:
data: "RoundingData=" + $.toJSON(data) + "&StateData=" + $.toJSON(stateData)和{ RoundingData:$.toJSON(data), StateData: $.toJSON(stateData)被 jquery 以相同的方式解释。好吧,实际上您的查询字符串实际上将被转换为实际 XHR 的总体方案中的对象。通过执行 GET 调用并将查询字符串添加到实际 URL,您可以避免该问题,但我不明白它为什么重要(我相信您有充分的理由)。而且,很明显,GET 无论如何都不是语义正确的 HTTP。 /咆哮。
标签: jquery asp.net-mvc ajax json