簡體   English   中英

使用2參數的odata v4

[英]odata v4 using 2 parameter

我只想將2參數傳遞到控制器中並運行sql函數try並用大量谷歌搜索沒有運氣,

有人可以給我一些提示嗎?

基本上我遵循此Web API和OData-傳遞多個參數

當我使用builder.Function編譯器時,請告訴我未找到擴展方法。

package.config

<?xml version="1.0" encoding="utf-8"?>
<packages>
  <package id="EntityFramework" version="6.1.3" targetFramework="net452" />
  <package id="EntityFramework.Functions" version="1.4.0" targetFramework="net452" />
  <package id="Microsoft.AspNet.OData" version="6.0.0" targetFramework="net452" />
  <package id="Microsoft.AspNet.WebApi" version="5.2.3" targetFramework="net452" />
  <package id="Microsoft.AspNet.WebApi.Client" version="5.2.3" targetFramework="net452" />
  <package id="Microsoft.AspNet.WebApi.Core" version="5.2.3" targetFramework="net452" />
  <package id="Microsoft.AspNet.WebApi.OData" version="5.3.1" targetFramework="net452" />
  <package id="Microsoft.AspNet.WebApi.WebHost" version="5.2.3" targetFramework="net452" />
  <package id="Microsoft.CodeDom.Providers.DotNetCompilerPlatform" version="1.0.0" targetFramework="net452" />
  <package id="Microsoft.Data.Edm" version="5.6.0" targetFramework="net452" />
  <package id="Microsoft.Data.OData" version="5.6.0" targetFramework="net452" />
  <package id="Microsoft.Extensions.DependencyInjection" version="1.0.0" targetFramework="net452" />
  <package id="Microsoft.Extensions.DependencyInjection.Abstractions" version="1.0.0" targetFramework="net452" />
  <package id="Microsoft.Net.Compilers" version="1.0.0" targetFramework="net452" developmentDependency="true" />
  <package id="Microsoft.OData.Core" version="7.0.0" targetFramework="net452" />
  <package id="Microsoft.OData.Edm" version="7.0.0" targetFramework="net452" />
  <package id="Microsoft.Spatial" version="7.0.0" targetFramework="net452" />
  <package id="Newtonsoft.Json" version="6.0.4" targetFramework="net452" />
  <package id="System.Spatial" version="5.6.0" targetFramework="net452" />
</packages>

我的WebApiConfog.cs

using Microsoft.OData.Edm;
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
using System.Web.Http;
using System.Web.Http.OData.Builder;
using System.Web.Http.OData.Extensions;
using wcod;
using wcod.Model;
namespace wcod
{
    public static class WebApiConfig
    {
        public static void Register(HttpConfiguration config)
        {
            // Web API configuration and services
            ODataModelBuilder builder = new ODataConventionModelBuilder();

            //  config.Count().Filter().OrderBy().Expand().Select().MaxTop(null);

            var json = config.Formatters.JsonFormatter;
            json.SerializerSettings.PreserveReferencesHandling = Newtonsoft.Json.PreserveReferencesHandling.Objects;
            config.Formatters.Remove(config.Formatters.XmlFormatter);



            config.Formatters.Remove(config.Formatters.XmlFormatter);
            config.Formatters.JsonFormatter.SerializerSettings.Formatting = Formatting.Indented;
            config.Formatters.JsonFormatter.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();
            // var json = config.Formatters.JsonFormatter;
            // builder.EntitySet<Booking>("Bookings");
            builder.EntitySet<LiveBooking>("LiveBookings");
            builder.EntitySet<TimeMarker>("TimeMarkers");
            builder.EntitySet<BookingInfo>("BookingInfoes");
            builder.EntitySet<LiveBookingByType>("LiveBookingByTypes");






            config.MapHttpAttributeRoutes();

            config.Routes.MapHttpRoute(
                name: "DefaultApi",
                routeTemplate: "api/{controller}/{id}",
                defaults: new { id = RouteParameter.Optional }
            );
            config.Routes.MapODataServiceRoute("odata", "odata/v4", builder.GetEdmModel());
            // config.MapODataServiceRoute( routeName: "ODataRoute", routePrefix: "odata/v4", model: builder.GetEdmModel());
        }

    }
}

您應該使用System.Web.OData.Builder而不是System.Web.Http.OData.Builder 它應該在Microsoft.AspNet.OData包中。

如果.GetEdModel()引發異常,則可能是您的定義有問題,而不是使用。

好吧,我遵循這種方法:

WebApiConfig.cs

using System.Web.Http;
using System.Web.OData.Extensions;
using System.Web.OData.Builder;
//using System.Web.OData.Extensions;
using wcod.Model;

namespace wcod
{
    public static class WebApiConfig
    {
        public static void Register(HttpConfiguration config)
        {
            // Web API configuration and services
            ODataModelBuilder builder = new ODataConventionModelBuilder();
            config.Count().Filter().OrderBy().Expand().Select().MaxTop(null);

            builder.EntitySet<TimeMarker>("TimeMarkers");

            var function = builder.Function("GetTimeMarkerSearch");
            function.Parameter<string>("bookID");
            function.Parameter<string>("keywords");
            function.ReturnsCollectionFromEntitySet<TimeMarker>("TimeMarkers");
                config.MapHttpAttributeRoutes();

            //config.Routes.MapODataServiceRoute("odata", "odata/v4", builder.GetEdmModel());

            config.MapODataServiceRoute("odata", "odata/v4", builder.GetEdmModel());
        }

    }
}

然后在我的控制器中,mycase TimeMarkersControllers

[HttpGet]
[ODataRoute("GetTimeMarkerSearch(bookID={bookID},keywords={keywords})")]
public IHttpActionResult WhateverName([FromODataUri]string bookID, [FromODataUri]string keywords){
// my logic
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM