gpt4 book ai didi

asp.net-web-api - ASP.NET WebAPI OData - 继承自 EntitySetController<> 但使用 Get(ODataQueryOptions options) 而不是 [Queryable]Get()

转载 作者:行者123 更新时间:2023-12-04 13:33:17 27 4
gpt4 key购买 nike

我正在使用 ASP.Net WebAPI nightly build (2013-01-16) 来获得最新的 OData 支持。

作为Meta-Me blog on MSDN OData 0.2.0-alpha release post说,现在有一个 EntitySetController<T>可以从中派生出 OData Controller ,从而消除大量的痛苦和管道代码。
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 - 这是我目前无法发现的类型)。

但是,如果我尝试在我自己的 Controller 中使用基于 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 路由术语)在 Controller 的基类以及 Controller 类本身上看到 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();

}

没有调用其他配置来处理路由或处理程序等。请注意,根据 this,HttpConfiguration 上的 EnableOData() 方法不再存在于最新的夜间构建中。 CodePlex 讨论。

非常感谢!

最佳答案

很高兴看到您正在使用我们的夜间版本 :)

您收到多个匹配操作错误的原因是 EntitySetController 已经定义了一个 Get 方法。好消息是 EntitySetController 还定义了一个 QueryOptions可用于检索查询选项的属性。因此,您应该能够覆盖 EntitySetController 的 Get 方法并使用查询选项属性而不是参数。它的行为方式应该与您将查询选项绑定(bind)到操作参数的方式完全相同。

关于asp.net-web-api - ASP.NET WebAPI OData - 继承自 EntitySetController<> 但使用 Get(ODataQueryOptions options) 而不是 [Queryable]Get(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14392677/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com