MVC 应用程序中的 Ajax Post 参数始终为空

Bob*_*Bob 4 parameters ajax asp.net-mvc null post

我有一个适用于测试应用程序的简单帖子

控制器代码

public ActionResult Delete(string Id)
{
    ... delete record ...
}
Run Code Online (Sandbox Code Playgroud)

JavaScript

function delAnnouncement(id) {
    $.ajax({
        type: "POST",
        url: "@Url.Action("Delete", "Announcements")",
        contentType: "application/json; charset=utf-8",
        data: JSON.stringify({ "Id": "03d23684-098a-4ae8-8fa2-7d9ce70d63ef" }), // Hard coded for testing
        success: function (data) {
            $("#AnnouncementsPH").replaceWith(data);
        }
    });        
}
Run Code Online (Sandbox Code Playgroud)

我创建了一个简单的测试应用程序,它可以在那里工作。

我正在寻找有关现有应用程序中可能存在的始终导致传递的 id 为空的内容的任何想法。

我尝试过的事情:
两个应用程序之间的路由信息​​相同。
它们都是安全的 https 网站。
现有网站上的其他表格按预期工作。这是唯一使用带有参数的 javascript 帖子的地方。它只是列出任何系统公告的新视图。
据我所知,HTML 是有效的。
Fiddler 显示正在发送数据。
我试图简单地硬编码Id通过。

我不知道是什么原因导致Post无法工作。

感谢您的任何建议

编辑 1:这是提琴手的原始帖子

POST https://localhost:44300/Announcements/Delete HTTP/1.1
Host: localhost:44300
Connection: keep-alive
Content-Length: 39
Accept: */*
Origin: https://localhost:44300
X-Requested-With: XMLHttpRequest
Content-TypeOfNotification: application/json; charset=utf-8
User-Agent: Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/36.0.1985.125 Safari/537.36
Content-Type: text/plain;charset=UTF-8
Referer: https://localhost:44300/
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Cookie: jetbrains.charisma.main.security.PRINCIPAL=NmI4YmFhZTExMThjZDZkZjNmZTBhMDNiZWM4NmY3MDYzZWNiMWE3M2ZmZDM5ODMwYjViMjczN2ZkZmU3YmZlZTpyb290; TCSESSIONID=233EBE63123BA35468235F441F54D7E4; ASP.NET_SessionId=ycnx1ejeyahzipwduux2quqz; __RequestVerificationToken=FnOKGFfBZKEBX4E0KBoV9133e5KK3h9Pd_OjDzNPjv7ifMTMk5uHUPmT621hOQFyOCwW5IhdewKLPDMs2_9jY2vVwrHLYOU9f0F86mN-NoQ1; .AspNet.ApplicationCookie=V8ZnbAx_2_H1Wx946VLcQ235XplzC-uvKdw4CP7Sm8ZVnJu9pG63EuzC0ptOZZNBvzZkRjB0RJS25Pn1WHOzeQSrqoWl87keqRDS6_vMwZ9L6PgKU0rJz7OhD7eKps8l3tzR097zI5WbU_chUZFKLLw1c__rfN3Fy6BbHC1qNtgx0C86AShhG5EsNiruYqJZn-Uj7Z2h75YcZctCFniMyuzD-9RetcMjkN3_PbAJg-_urfntG9NwsMEQdBf1b3K9H3GP_wUYRhnbQdNZpuAkAEa6bVfJiHrnKFhnhLkP8BAfocbMKES1wQKbXBfcNn62cEKUu3On3lHNCNN4zEvOhxF1aDaBk-yghOtvtNkROeFTKMQFD0U-XXAf-RKm0Nwgp1Tb2Ip2U42vshDRNGXQSkOojisVUxiPmkrxDtckNycQd0br1cFSqxfeXyg3cg_vKUP1VMBQcBQxZO6MVLSCDdcpANyoE43IoLp3BHgURJZP88vF18JfVV646XGOZ3QU

Id=03d23684-098a-4ae8-8fa2-7d9ce70d63ef
Run Code Online (Sandbox Code Playgroud)

如您所见,Id 已发布到控制器,只是未解析并提供给方法中的参数。

小智 5

您可以附加参数,如:

var targeturl = '@Url.Action("Test", "Controller")?id=' + ID;

$.ajax({
    url: targeturl,
    type: "GET",
    success: function(data) { },
    error: function (data) { }
});
Run Code Online (Sandbox Code Playgroud)

或者你可以直接使用 jQuery ajax 数据参数:

$.ajax({
  type: "POST",
  url: '@Url.Action("Test", "Controller")',
  data: { id: "your-id" }
})
  .done(function( msg ) {
    alert( "Data Saved: " + msg );
  });
Run Code Online (Sandbox Code Playgroud)

参考资料:http : //api.jquery.com/jquery.ajax/


小智 5

我在其他任何地方都没有找到这个答案,所以我不得不通过实验来发现它。

  1. 你会发现在你的控制器中,它正在接收一个Request.Form对象,如果你查看Request.Form[0]你会发现你的数据。表单中有数据但 MVC 认为它的原因null是要发布的表单元素的键是""(空白)。

  2. 因此,客户端,您必须正确设置内容类型,并在您的数据前面加上"data=" + JSON.stringify(mydata)"data"您要添加的键名在哪里。

像这样:

$.ajax({
    type: "POST",
    url: URL,
    data: "data="+JSON.stringify(data),
    contentType: "application/x-www-form-urlencoded; charset=utf-8"
Run Code Online (Sandbox Code Playgroud)

在服务器端,您的[HttpPost]端点必须具有与您在 AJAX 中声明的键同名的变量作为其输入,如下所示:

[HttpPost]
[Authorize]
public ActionResult Index (string data) // <-- key name
{
   MyObjectType MyFinalObject = JsonConvert.DeserializeObject<MyObjectType (data);
}
Run Code Online (Sandbox Code Playgroud)