我有一个带有ApiController
的ASP.NET Web API项目,它提供了一个具有以下操作的User
端点:
GET /api/User
POST /api/User
DELETE /api/user
我想提供以下端点:
GET /api/user/metrics
但是,当我像这样定义控制器操作时:
[HttpGet]
public HttpResponseMessage Metrics()
{
return null;
}
我收到Multiple actions were found that match the request
错误消息。
我知道这违反了“纯”REST API的定义,但我想这样做。我想我必须通过映射一个HTTP路由来解决这个问题,但是我已经尝试了几个路由,但是我不能让它工作。我的路线应该是什么样子的?
发布于 2014-01-16 13:03:23
默认路由不包括该操作。
routes.MapHttpRoute(
name: "API Default",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
它根据控制器、HTTP谓词和路由中的参数或缺少参数来选择操作。因此,它正在寻找正确的控制器,并寻找一个不带参数的GET操作。它会找到两个。
您应该添加一个包含该操作的附加路由。这可以通过Kiran提到的基于属性的路由或基于约定的路由来完成。对于基于约定的路由,路由通常放在WebApiConfig.cs
的Application_start()
方法中。更具体的路由放在一般路由之前,因此您的路由将如下所示:
config.Routes.MapHttpRoute(
name: "ApiWithAction",
routeTemplate: "api/{controller}/{action}/{id}",
defaults: new { id = RouteParameter.Optional }
);
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
发布于 2014-01-16 10:39:58
如果您使用的是Web API 2,我建议您使用属性路由,这将使此类场景的体验变得更容易。
您可以在大多数场景中继续使用默认的常规路由,但可以在需要的地方使用属性路由,如在当前场景中。
下面的示例演示了一个类似的场景:
https://stackoverflow.com/questions/21152168
复制相似问题