5

像我之前的许多人一样,我正在尝试将多个参数传递给 Web API 项目。我已经尝试了这个网站上提供的几种解决方案,但都没有成功。我最近失败的迭代如下所示:

控制器

public class UserDTO
{
   public int userID;
   public string username;
}

[HttpPost]
public string Post([FromBody]UserDTO userDTO)
{
   return userDTO.userID.ToString() + " " + userDTO.username;
}

Web API 路由配置

config.Routes.MapHttpRoute(
   name: "DefaultApi",
   routeTemplate: "api/{controller}/{id}",
   defaults: new { id = RouteParameter.Optional }
);

jQuery

var apiUrl = "http://localhost:55051/api/User/Post";
var userDTO = {
   userID: 5,
   username: "testuser"
};

$.ajax({
   type: "POST",
   url: apiUrl,
   data: JSON.stringify(userDTO),
   datatype: "json",
   contenttype: "application/json; charset=utf-8"
)};

提琴手输出

Fiddler 显示正确传递的 JSON 变量,在原始视图中我可以看到:

{"userID":5,"username":"testuser"}

执行时

userID = 0
username = null

帮助!

我认为问题出在 Web API 上,鉴于我的 POST 在 Fiddler 中的格式似乎正确,因此很难使用 JSON 参数。有任何想法吗?

4

2 回答 2

2

你的 jQuery ajax 调用不会失败吗?检查它?

var apiUrl = "http://localhost:55051/api/UserController/Post";

看到您的代码,这应该是:

var apiUrl = "http://localhost:55051/api/User";

控制器一词通常不是您的 URL 的一部分。您不必显式调用 POST,它应该按照惯例选择它,因为您的 ajax 调用是 POST。

编辑:

上面的内容和您在 ajax 调用中的外壳已评论。

我个人使用 Firebug(Firefox 扩展)来调试这些案例。在这种情况下,如果发现它比提琴手更方便。

于 2013-06-17T21:24:37.460 回答
1

我的猜测是你必须通过: { userDTO : { userID ... } } 作为 jquery 中的数据。请求被包装。当然,您必须对此进行字符串化。

现在您传递参数,但它们都不匹配 userDTO,因此它获取默认值。

在这里查看我以前的答案:Jquery post

于 2013-06-17T21:32:06.003 回答