[英]Trouble enabling OData v4.0 routing in ASP.NET Web API 2.2
我正在尝试在我的 ASP.NET web api 中实现 OData 路由。 作为指导,我查看了本教程: http : //www.asp.net/web-api/overview/odata-support-in-aspnet-web-api/odata-v4/create-an-odata-v4-endpoint .
但是,我一直在 MapODataServiceRoute() 函数中收到错误消息。 显然,该函数需要一个 Microsoft.OData.Edm.IEdmModel,而我的构建器的 GetEdmModel() 函数只返回 Microsoft.Data.Edm.IEdmModel。
我在网上做了一些研究。 Microsoft.Data.Edm 是旧版 OData 的库。 Microsoft.OData.Edm 适用于 OData v4.0,这就是我在 WebApiConfig.cs 文件中注释掉 Microsoft.Data.Edm 的原因。 这是我的代码。
using MyApp.Models;
// using Microsoft.Data.Edm;
using Microsoft.OData.Edm;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Net.Http.Headers;
using System.Web.Http;
using System.Web.Http.OData.Builder;
using System.Web.OData.Extensions;
using System.Web.OData.Routing;
namespace MyAppAPI
{
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
// Enable attribute routing
config.MapHttpAttributeRoutes();
// Enable OData routing
config.MapODataServiceRoute(
routeName: "MyApp",
routePrefix: "odata",
model: GetEdmModel());
// Conventional routing
config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
);
// Uncomment the following line of code to enable query support for actions with an IQueryable or IQueryable<T> return type.
// To avoid processing unexpected or malicious queries, use the validation settings on QueryableAttribute to validate incoming queries.
// For more information, visit http://go.microsoft.com/fwlink/?LinkId=279712.
config.EnableQuerySupport();
// To disable tracing in your application, please comment out or remove the following line of code
// For more information, refer to: http://www.asp.net/web-api
config.EnableSystemDiagnosticsTracing();
// Trying to get most browsers (i.e. Google Chrome) to return JSON
config.Formatters.JsonFormatter.SupportedMediaTypes.Add(new MediaTypeHeaderValue("text/html"));
}
// Configure modesl to use Odata
public static IEdmModel GetEdmModel()
{
ODataConventionModelBuilder builder = new ODataConventionModelBuilder();
builder.EntitySet<ModelA>("ModelA");
builder.EntitySet<ModelB>("ModelB");
return builder.GetEdmModel();
}
}
}
但是,我仍然收到一条错误消息:
Error 1 Cannot implicitly convert type 'Microsoft.Data.Edm.IEdmModel' to 'Microsoft.OData.Edm.IEdmModel'. An explicit conversion exists (are you missing a cast?)
有没有一种干净的方法来获得 Microsoft.OData.Edm.IEdmModel? 还是我只需要做演员?
用 System.Web.OData.Builder 替换 System.Web.Http.OData.Builder 似乎有效。
这是带有解释的链接: https : //devblogs.microsoft.com/aspnet/getting-started-with-asp-net-web-api-2-2-for-odata-v4-0/
我认为这条线几乎总结了它:
程序集名称和根命名空间现在是 System.Web.OData 而不是 System.Web.Http.OData。
我现在使用的标题是:
using MyApp.Models;
// using Microsoft.Data.Edm;
using Microsoft.OData.Edm;
using System.Net.Http.Headers;
using System.Web.Http;
// using System.Web.Http.OData.Builder;
using System.Web.OData.Builder;
using System.Web.OData.Extensions;
请用
using Microsoft.AspNet.OData.Builder;
using Microsoft.AspNet.OData.Extensions;
代替
using System.Web.OData.Builder;
using System.Web.OData.Extensions;
我希望这会有所帮助,当我尝试执行相同的示例时遇到了同样的错误,我只是通过包管理器控制台执行了以下操作
1- unInstall-Package Microsoft.OData.Edm -Force 2- Install-Package Microsoft.OData.Edm
那么它对我来说很好用。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.