ASP.NET Web API的默认路由在App_Start目录中的WebApiConfig.cs文件中定义的。
public static class WebApiConfig { public static void Register(HttpConfiguration config) { // Web API 配置和服务 // Web API 路由 config.MapHttpAttributeRoutes(); config.Routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{id}", defaults: new { id = RouteParameter.Optional } ); } }
路由表中的每个条目都包含一个路由模板。Web API的默认路由模板是“api / {controller} / {id}”。在此模板中,“api”是文字路径段,{controller}和{id}是占位符变量。
当Web API框架收到HTTP请求时,它会尝试将URI与路由表中的某个路由模板进行匹配。如果没有路由匹配,则客户端收到404错误。
找到匹配的路由后,Web API将选择控制器和操作:
- 要查找控制器Controller,Web API会将“Controller”添加到{controller}变量的值中。
- 要查找操作方法action,Web API会查看HTTP方法,然后查找名称以该HTTP方法名称开头的操作。例如,对于GET请求,Web API会查找以“Get ...”开头的操作,例如“GetContact”或“GetAllContacts”。此约定仅适用于GET,POST,PUT和DELETE方法。
- 路径模板中的其他占位符变量(例如{id})将映射到操作参数。
按操作名称路由
使用默认路由模板,Web API使用HTTP方法选择操作。但是,您也可以创建一个路径,其中操作名称包含在URI中:
routes.MapHttpRoute( name: "ActionApi", routeTemplate: "api/{controller}/{action}/{id}", defaults: new { id = RouteParameter.Optional } );
在此路由模板中,{action}参数在控制器上命名操作方法。使用此样式的路由,使用属性指定允许的HTTP方法。
public class ProductsController : ApiController { [HttpGet] [ActionName("Thumbnail")]//使用ActionName属性覆盖操作名称 public HttpResponseMessage GetThumbnailImage(int id); [HttpPost] [ActionName("Thumbnail")] public void AddThumbnailImage(int id); //非操作:要防止将方法作为操作调用,请使用NonAction属性。这向框架发出信号,表明该方法不是动作,即使它与路由规则匹配。 // Not an action method. [NonAction] public void DeleteThumbnailImage(int id); }
路由有三个主要阶段:
- 将URI与路由模板匹配。
- 选择一个控制器。
- 选择一个动作。
路由模板:Route Templates
1、路由模板类似于URI路径,但它有占位符值,用花括号表示,其中 占位符匹配任何值。
"api/{controller}/{category}/{id}"
2、创建路径是,可以部分或者全部为占位符提供默认值:
defaults: new { category = "all" }
3、还可以提供约束,用以约束现在URI段与占位符匹配的方式:
constraints: new { id = @"d+" } // Only matches if "id" is one or more digits.
默认
如果提供默认值,则路由将匹配缺少这些段的URI。例如:
routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{category}", defaults: new { category = "all" } );
URI“http://localhost/api/products
”匹配此路由。“{category}”段被分配了默认值“all”。
Route Dictionary
如果框架找到URI的匹配项,它将创建一个包含每个占位符的值的字典。键是占位符名称,不包括花括号。值来自URI路径或默认值。字典存储在IHttpRouteData对象中。
在此路由匹配阶段,特殊的“{controller}”和“{action}”占位符将被视为与其他占位符一样。它们只是与其他值一起存储在字典中。
默认值可以具有特殊值RouteParameter.Optional。如果为占位符分配了此值,则该值不会添加到路径字典中。例如:
routes.MapHttpRoute( name: "DefaultApi", routeTemplate: "api/{controller}/{category}/{id}", defaults: new { category = "all", id = RouteParameter.Optional } );
对于URI路径“api / products”,路由字典将包含:
- controller: "products"
- category: "all"
但是,对于“api / products / toys / 123”,路线词典将包含:
- controller: "products"
- category: "toys"
- id: "123"
默认值还可以包含不会出现在路径模板中任何位置的值。如果路由匹配,则该值存储在字典中。例如:
routes.MapHttpRoute( name: "Root", routeTemplate: "api/root/{id}", defaults: new { controller = "customers", id = RouteParameter.Optional } );
如果URI路径为“api / root / 8”,则字典将包含两个值:
- controller: "customers"
- id: "8"