asp.net-web-api – ASP.NET WebAPI OData – 继承自EntitySetControl
|
我正在使用ASP.Net WebAPI每晚构建(2013-01-16)以获得最新的OData支持. 正如Meta-Me blog on MSDN OData 0.2.0-alpha release post所说,现在有一个EntitySetController< T>可以从中导出OData控制器来消除很多痛苦和管道代码. EntitySetController< T> class实现Get()为 [Queryable]
public virtual IQueryable<TEntity> Get()
{
throw EntitySetControllerHelpers.GetNotImplementedResponse(Request);
}
我想利用ASP.Net Web API OData支持提供的更具体的Get(ODataQueryOptions选项)方法. 我把它编码为 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();
}
(我也有这个返回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,PublicKeyToken=b77a5c561934e089]] 我假设这是由于路由解析器(抱歉,如果这是糟糕的ASP.NET路由术语)在控制器的基类以及控制器类本身上看到Get()或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 CodePlex讨论,HttpConfiguration上的EnableOData()方法不再存在于最新的每晚构建中. 非常感谢! 解决方法很高兴看到你正在使用我们的夜间构建:)您获得多个匹配操作错误的原因是因为EntitySetController已经定义了一个Get方法.好消息是EntitySetController还定义了一个QueryOptions属性,可用于检索查询选项.因此,您应该能够覆盖EntitySetController的Get方法,并使用查询选项属性而不是参数.它的行为应该与将查询选项绑定到action参数的方式完全相同. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-mvc – ASP.NET MVC HTML帮助程序可以渲染没有ID属
- asp.net – 使用json仅序列化对象的一部分
- asp.net – AppHarbor:不允许使用目录’/ App_GlobalResou
- asp.net-mvc – ExceptionContext.ExceptionHandled更改为t
- asp.net – ELMAH – 过滤404错误
- 使用Asp.Net进行异步编程的最佳方法
- 使用ASP.NET MVC和JQuery表单插件/文件上传检测IsAjaxReque
- 从ASP.NET MVC应用程序中的Amazon SES发送电子邮件
- iis-7 – ASP.NET MVC4在IIS7集成模式下不处理POST请求,但在
- asp.net – 如何在WebAPI中获取POST数据?
- 如何保护我的ASP.NET AJAX应用程序?
- asp.net – 对于在Azure部署的Web.config中存储密
- asp.net-mvc – 防止用户没有确认的电子邮件登录
- asp.net – Server.Transfer vs. Context.Rewrit
- 将虚拟路径转换为ASP.NET中的实际Web路径
- asp.net-mvc – MVC控制器正在被调用两次
- 验证 – Asp.Net MVC:子请求的执行失败.请查看I
- 在asp.net mvc上传文件代码后,通过服务器获
- asp.net – Ajax Tookit TabPanel Invisible Tag
- 在ASP.NET应用程序的global.asax中处理Applicati
