繁体   English   中英

在 ASP.NET Web API 2.2 中启用 OData v4.0 路由时出现问题

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM