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

时间:2016-03-08 04:14:29

标签: javascript c# ajax asp.net-mvc

问题

我想使用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);
}

问题始于服务器端,其中所有方法参数都为空。

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

问题

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

额外研究

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

为什么我这样做?

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

4 个答案:

答案 0 :(得分:2)

尝试以这种方式进行ajax调用,我认为这是发出请求的最佳方式

.indexof()

并且操作方法将是

    function SendForm() {
            var data = {};
            data.value1 = "Hello";
            data.value2 = "World";

            $.ajax({
                url: "http://server/controller/SomeAction",
                type: "POST",
                dataType: "json",
                data: JSON.stringify(data),
                contentType: "application/json; charset=utf-8;",
                success: function (data) {
                    // your code in success
                    alert("success");
                }
            });
        }

答案 1 :(得分:1)

0

答案 2 :(得分:1)

 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: formData, value1: "hello", value2: "world"},
    success: function (data) {
    // ..... any success code you want
    }
  });
  

在服务器端接收JSON

请试试这个。我现在无法在项目上运行代码。这是理论,但你可以使用AJAX单独传递数据

  

如果只需要value1和value2 - 服务器

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

JQuery的

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

答案 3 :(得分:1)

尝试以这种方式使用AJAX,

function SendForm() {      
       $.ajax({
                type: 'POST',
                url: '/controller/SomeAction',
                data: { value1 : 'hello', value2 : 'world' },
                success: function (result) {
                    //Your success code here..
                },
                error: function (jqXHR) {                        
                    if (jqXHR.status === 200) {
                        alert("Value Not found");
                    }
                }
            });
     }

您可以找到value1value2到服务器端。

<强>控制器

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