我正在使用 ASP.Net WebAPI nightly build (2013-01-16) 来获得最新的 OData 支持。
正如MSDN OData 0.2.0-alpha 发布帖子上的 Meta-Me 博客所说,现在EntitySetController<T>
可以从中派生出 OData 控制器,以消除很多痛苦和管道代码。
该类将EntitySetController<T>
Get() 实现为
[Queryable]
public virtual IQueryable<TEntity> Get()
{
throw EntitySetControllerHelpers.GetNotImplementedResponse(Request);
}
我想利用Get(ODataQueryOptions options)
ASP.Net Web API OData 支持提供的更具体的方法。
我把它编码为
public IEnumerable<Patient> Get(ODataQueryOptions options)
{
IQueryable patients = entities.Patients;
if (options.Filter != null)
{
patients = options.Filter.ApplyTo(patients, new ODataQuerySettings());
}
return (patients as IQueryable<Patient>).AsEnumerable();
}
(我也有这个 return IQueryable<> 并看到其他人谈论 ODataResult - 这是我目前无法发现的类型)。
但是,如果我尝试在我自己的控制器中使用基于 ODataQueryOptions 的 Get 方法,我会收到一条错误消息,说明与请求匹配的多个操作。具体来说,该错误是
Multiple actions were found that match the request:
System.Collections.Generic.IEnumerable`1[Dox.Server.Model.Patient] Get(System.Web.Http.OData.Query.ODataQueryOptions) on type Dox.Server.Web.Controllers.PatientController
System.Linq.IQueryable`1[Dox.Server.Model.Patient] Get() on type System.Web.Http.OData.EntitySetController`2[[Dox.Server.Model.Patient, Dox.Server.Model, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null],[System.Guid, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089]]
我认为这是由于路由解析器(对不起,如果这是糟糕的 ASP.NET 路由术语)在控制器的基类以及控制器类本身上看到 Get() 或 Get(...)。
问题: a) 有没有办法调整路线来解决这个问题?b)如果不是,我应该制作自己的版本EntitySetController<T>
并换掉它的 Get() 方法吗?
Application_Start() 调用的配置仅限于
public static void EnableOData( HttpConfiguration config )
{
var model = BuildModelImplicitly(config);
//As per LinqPad forum: http://forum.linqpad.net/discussion/178/odata-v3-not-working
IEdmEntityContainer container = model.EntityContainers().First();
model.SetIsDefaultEntityContainer(container, true);
//config.EnableOData(model, "api");
config.Routes.MapODataRoute("OData", "api", model);
//config.EnableSystemDiagnosticsTracing();
}
没有调用其他配置来处理路由或处理程序等。请注意,根据此CodePlex 讨论,最新的夜间构建中不再存在 HttpConfiguration 上的 EnableOData() 方法。
非常感谢!