官术网_书友最值得收藏!

Attribute-based routing

Attribute-based routing allows you to control the exact route that each controller and action takes part in by using the attributes that decorate your controllers and methods. I recommend that you use this approach for most of your APIs, since it will make your code more explicit and reduce routing errors that might be introduced as you add more controllers and actions.

At the beginning of this chapter, we created the ProductsController, which looked like this:

[Route("api/Products")]
[ApiController]
public class ProductsController : Controller
{
...
}

The RouteAttribute attribute that decorates the ProductController contains the URL template that maps to this controller. In this case, every request with a URL prefixed with /api/products/ will be routed to this controller. You can use the RouteAttribute attribute on controllers and on methods, but for methods, it's recommended to use the Http[Verb]Attribute attribute, where [Verb] is one of the standard HTTP verbs (Get, Post, Put, Delete, and so on).

The Http[Verb]Attribute and RouteAttribute attributes can be assigned multiple times to define multiple routes, and are hierarchical, which means that they support route inheritance. This means that if you configured a route on your controller, the routes you define on the methods will extend it.

For example, here is how you can configure that the ProductsController.GetProducts method will be mapped to a HttpGet request to the URL /api/products/all, in addition to the URL /api/products:

[HttpGet]
[HttpGet("all")]
public string[] GetProducts()
{
...
}
If the Http[Verb]Attribute that you set on a method contains a string that begins with /, then it won't be combined with the route defined in the controller, and will instead define a route of its own.
主站蜘蛛池模板: 西乌珠穆沁旗| 萨嘎县| 额敏县| 静宁县| 罗城| 松潘县| 茶陵县| 钟祥市| 仪征市| 安图县| 藁城市| 毕节市| 临江市| 博客| 尼木县| 舒城县| 深水埗区| 钟祥市| 玉屏| 襄樊市| 彝良县| 沧州市| 清镇市| 海林市| 桃江县| 黔南| 安福县| 石阡县| 筠连县| 竹北市| 黄大仙区| 高邑县| 乐亭县| 板桥市| 博野县| 冕宁县| 于田县| 北宁市| 祁门县| 永安市| 柏乡县|