javascript – 使用Ajax将表单数据发布到控制器方法

问题

我想使用AJAX异步地将表单数据发布到控制器.这是我的JavaScript的简化视图:

function SendForm() {
  var formData = new FormData();
  formData.append('value1', 'hello');
  formData.append('value2', 'world');
  var xhr = new XMLHttpRequest();
  xhr.upload.onload = function() {
    // stuff that happens on the callback
  };
  xhr.open('POST', 'http://server/controller/SomeAction', true);
  xhr.setRequestHeader('Content-Type', 'multipart/form-data');
  xhr.send(formData);
}

问题始于服务器端,其中所有方法参数均为null.

[HttpPost]
public ContentResult SomeAction(string value1, string value2)
{
  if(String.IsNullOrEmpty(value1) || String.IsNullOrEmpty(value2)) { throw new Exception("World not found."); }
  return Content("something");
}

问题

我的问题是,为什么所有方法参数都为null?

额外研究

我查看了请求流,我可以从长度上看到那里有内容,但无论出于什么原因,MVC都无法将我在FormData对象中指定的参数与控制器中的methed中的参数相匹配.

我为什么这样做?

是的,我想发布数据.我已经简化了示例,但是我希望发布的数据多于可以放在URL上的数据,因此对于此解决方案,REST方法(在查询字符串上传递数据)是不可接受的.

解决方法:

 function SendForm() {
   var formData = new FormData();
   formData.append('value1', 'hello');
   formData.append('value2', 'world');
   $.ajax({
     url: "http://server/controller/SomeAction",
     type: 'post',
      cache: false,
      contentType: false,
      processData: false,
      data: formData,
      success: function (data) {
        // ..... any success code you want
    }
   });

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...