使用superagent将ajax发布到ASP.NET MVC端点,绑定到IEnumerable <int>属性

时间:2017-11-08 11:51:49

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

通过superagent向ASP.NET MVC3端点发出Ajax post请求。 UserName正确绑定并作为“foobar”#39;来自&#39; foobar&#39;。 但是,RoleIds(IEnumerable&lt; int&gt;)为null。

我目前的实现如下:

服务器:(C#,MVC3)

public class AddUserViewModel 
{
  public string UserName { get; set;}
  public IEnumerable<int> RoleIds { get; set; }
}  

public class UserManagementController : Controller {
    ...
    [HttpPost]        
    public virtual ActionResult AddUser(AddUserViewModel addUserViewModel) {
        ...
    }
    ...
}

客户端(Javascript):

const data = {
    UserName: 'foobar',
    RoleIds: [1, 2]
}

superagent.post('/AddUser')
.send(data)
.then((res) => console.log(res))

我的请求如下:

{"UserName":"foobar","RoleIds":[1,2]}

我学到的东西我想我必须以下列格式发布我的请求:

UserName=foobar&RoleIds=1&RoleIds=2

如何使superagent以正确的格式格式化请求,以便MVC3端点正确绑定它? (在jQuery中有一些traditional选项可以解决这个问题。)

1 个答案:

答案 0 :(得分:0)

好的让它发挥作用。

应该将Content-Type设置为application/x-www-form-urlencoded,然后以正确的格式发送请求,如下所示:

UserName=foobar&RoleIds=1&RoleIds=2

所以请求必须这样做:

const data = {
  UserName: 'foobar',
  RoleIds: [1, 2]
}

superagent.post('/AddUser')
.send(data)
.set('Content-Type', 'application/x-www-form-urlencoded')
.then((res) => console.log(res))