使用 Ajax 将表单数据发布到控制器方法
Posting form data to a controller method using 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");
}
问题
我的问题是,为什么所有方法参数都为空?
额外研究
我已经查看了请求流的内部,从长度可以看出那里有内容,但是无论出于何种原因,MVC 都无法将我在 FormData 对象中指定的参数与控制器中 methed 中的参数匹配。
我为什么要这样做?
是的,我想发布数据。我已经简化了示例,但我想发布的数据多于可以放置在 URL 上的数据,因此此解决方案不接受 REST 方法(在查询字符串上传递数据)。
尝试以这种方式调用 ajax,我认为这是发出请求的最佳方式
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");
}
});
}
并且操作方法将是
[HttpPost]
public JsonResult SomeAction(string value1, string value2)
{
if(String.IsNullOrEmpty(value1) || String.IsNullOrEmpty(value2))
{
throw new Exception("World not found.");
}
return Json("something");
}
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
}
});
尝试以这种方式使用 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");
}
}
});
}
您可以在服务器端找到value1
和value2
。
控制器
[HttpPost]
public ContentResult SomeAction(string value1, string value2)
{
if(String.IsNullOrEmpty(value1) || String.IsNullOrEmpty(value2)) { throw new Exception("World not found."); }
return Content("something");
}
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单独传递数据
如果只有值 1 和值 2 是必需的 - 服务器
[HttpPost]
public JsonResult SomeAction(string value1, string value2)
{
if(String.IsNullOrEmpty(value1) || String.IsNullOrEmpty(value2)) { throw
new Exception("World not found."); }
return Content("something");
}
杰奎里
$.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
}
});
相关文章:
- 如何在单击复选框后调用控制器方法
- 在嵌套递归指令中将参数传递给父控制器方法
- 如何在使用$timeout进行指令渲染后调用控制器方法
- 使用javascript将控制器方法移动到客户端
- AngularJS在页面重定向上执行控制器方法
- 如何从弹簧控制器方法更新html img src
- 表单提交未到达控制器方法
- 使用 $.getJson 方法从 jquery 调用 C# MVC 控制器方法
- 如何将对象列表传递到MVC4中的控制器方法
- 如何将从jQuery创建的数组传递给控制器方法
- 通过javascript调用控制器方法
- 一键点击首先调用javascript,执行验证,然后调用控制器方法
- 窥探递归角度控制器方法
- Angular为不同的url调用不同的控制器方法
- 如何在 emberjs 中访问其他控制器方法
- 如何从Javascript函数调用控制器方法
- 调用控制器方法并在客户端上获取数据
- 离子:$ionicPlatform.isIOS()在控制器方法中不起作用
- 使用 Ajax 将表单数据发布到控制器方法
- 在 ember.js 中定义和使用控制器方法