ASP.NET API 路由
ASP.NET API routing
我正在研究 ASP.NET 5 API 并了解到,为了尽可能使 API 成为 "restful",我们使用 Http 动词作为方法名称。
我的问题是,如果我有多个方法执行不同的操作并且都必须是 HttpPost,会发生什么?
比如说,我有一个方法可以调用来更新用户的名字,并且可能有另一个方法可以用来更新用户的城市。在这两种情况下,输入参数都是用户 ID (GUID) 和字符串值。
[HttpPost("id")]
public void Post([FromRoute]id, [FromBody]firstName)
{
// Change user's first name
}
[HttpPost("id")]
public void Post([FromRoute]id, [FromBody]city)
{
// Change user's city
}
在这种情况下如何命名我的方法?
要有 2 个 post 方法做不同的事情,请使用 "ActionName" 属性。
[HttpPost("id")]
[ActionName("FirstNamePost")]
public void FirstNamePost([FromRoute]id, [FromBody]firstName)
{
// Change user's first name
}
[HttpPost("id")]
[ActionName("CityPost")]
public void CityPost([FromRoute]id, [FromBody]city)
{
// Change user's city
}
所以你会调用 "www.mysite.com/api/citypost/1" 或 "www.mysite.com/api/FirstNamePost/1"
另一种选择是只有一个 post 方法并添加第三个参数以区分名称更新或城市更新。
你可以给控制器一个路由前缀
[RoutePrefix("Note")]
public class NoteController
然后给出任何动作的具体路线
[Route("", Name = "Note")]
[HttpGet]
public async Task<IHttpActionResult> Get (string tenantName, [FromBody] TagTdo entity)
[Route("", Name = "CreateNote")]
[HttpPost]
public async Task<IHttpActionResult> Post (string tenantName, [FromBody] NoteDto entity)
[Route("Update\{id}", Name = "UpdateNote")]
[HttpPut]
public async Task<IHttpActionResult> Put(string tenantName, [FromBody] NoteDto entity)
那么路线将是:
\Note [GET]
\Note [POST]
\Note\Update [PUT]
还有一个命名约定,不要在路由中使用长名称,用斜线和 http 动词分成几个词
不要使用GetUserContacts
,使用User\Contacts [GET]
。
我正在研究 ASP.NET 5 API 并了解到,为了尽可能使 API 成为 "restful",我们使用 Http 动词作为方法名称。
我的问题是,如果我有多个方法执行不同的操作并且都必须是 HttpPost,会发生什么?
比如说,我有一个方法可以调用来更新用户的名字,并且可能有另一个方法可以用来更新用户的城市。在这两种情况下,输入参数都是用户 ID (GUID) 和字符串值。
[HttpPost("id")]
public void Post([FromRoute]id, [FromBody]firstName)
{
// Change user's first name
}
[HttpPost("id")]
public void Post([FromRoute]id, [FromBody]city)
{
// Change user's city
}
在这种情况下如何命名我的方法?
要有 2 个 post 方法做不同的事情,请使用 "ActionName" 属性。
[HttpPost("id")]
[ActionName("FirstNamePost")]
public void FirstNamePost([FromRoute]id, [FromBody]firstName)
{
// Change user's first name
}
[HttpPost("id")]
[ActionName("CityPost")]
public void CityPost([FromRoute]id, [FromBody]city)
{
// Change user's city
}
所以你会调用 "www.mysite.com/api/citypost/1" 或 "www.mysite.com/api/FirstNamePost/1"
另一种选择是只有一个 post 方法并添加第三个参数以区分名称更新或城市更新。
你可以给控制器一个路由前缀
[RoutePrefix("Note")]
public class NoteController
然后给出任何动作的具体路线
[Route("", Name = "Note")]
[HttpGet]
public async Task<IHttpActionResult> Get (string tenantName, [FromBody] TagTdo entity)
[Route("", Name = "CreateNote")]
[HttpPost]
public async Task<IHttpActionResult> Post (string tenantName, [FromBody] NoteDto entity)
[Route("Update\{id}", Name = "UpdateNote")]
[HttpPut]
public async Task<IHttpActionResult> Put(string tenantName, [FromBody] NoteDto entity)
那么路线将是:
\Note [GET]
\Note [POST]
\Note\Update [PUT]
还有一个命名约定,不要在路由中使用长名称,用斜线和 http 动词分成几个词
不要使用GetUserContacts
,使用User\Contacts [GET]
。