在 ASP.NET Core Web API 中创建 return OData 的 enbdpoints

Creating enbdpoints that return OData in ASP.NET Core Web API

我正在尝试在 ASP.NET Core Web API 中创建 OData 端点。

我使用模板创建了一个新的 ASP.NET Core Web API 并向其中添加了 Microsoft.AspNetCore.OData 包 (v7.0.0-beta1),假设它是必需的。

我找不到任何关于如何开始使用它的文档。如果有人能告诉我如何将默认的 ValuesController 简单地转换为 return OData 而不是 Json 那会很棒。

I created a new ASP.NET Core Web API using the template and added the Microsoft.AspNetCore.OData package (v7.0.0-beta1) to it assuming it is required.

I can't find any documentation on how to get started with this. If anyone can tell me how I would simply turn the default ValuesController to return OData instead of Json that would be great.

根据您的描述,我建议您可以尝试按照以下步骤来创建 net core odata web api。

1.Install Microsoft.AspNetCore.OData 7.0.0-beta1

2.Install Microsoft.EntityFrameworkCore

3.Create 模型 class 和 DBContext class.

public class Person
{
    [Key]
    public int Id { get; set; }
    [Required]
    public string Name { get; set; }
    [Required]
    public int Age { get; set; }
}

public class ApplicationDbContext : DbContext
{
    public ApplicationDbContext(DbContextOptions options)
        : base(options)
    {
    }


    public DbSet<Person> Persons { get; set; }

}

4.Create一个Controller,在OData早期版本中可以继承自ODataController。但是在 ASP.NET Core 中,没有可用的 OData 控制器。所以你需要创建一个带有OData属性的普通控制器。

public class PersonController : Controller
{
    private readonly ApplicationDbContext _appDbContext;
    public PersonController(ApplicationDbContext sampleODataDbContext)
    {
        _appDbContext = sampleODataDbContext;
    }

    [EnableQuery]
    public IActionResult Get()
    {
        return Ok(_appDbContext.Persons.AsQueryable());
    }
}

5.Modify 添加 OData 中间件和 OData 路由的启动 class 代码。

public class Startup
{
    public Startup(IConfiguration configuration)
    {
        Configuration = configuration;
    }

    public IConfiguration Configuration { get; }

    // This method gets called by the runtime. Use this method to add services to the container.
    public void ConfigureServices(IServiceCollection services)
    {
        services.AddDbContext<ApplicationDbContext>(options =>
options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));
        services.AddOData();
        services.AddMvc();

    }

    // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
    public void Configure(IApplicationBuilder app, IHostingEnvironment env)
    {
        //Adding Model class to OData
        var builder = GetEdmModel(app.ApplicationServices);
        builder.EntitySet<Person>(nameof(Person));

        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }

        app.UseMvc((routebuilder =>
        {
            routebuilder.MapODataServiceRoute("odata","odata", builder.GetEdmModel());
        }));
    }

    private static ODataConventionModelBuilder GetEdmModel(IServiceProvider serviceProvider)
    {
        var builder = new ODataConventionModelBuilder(serviceProvider);
       
      return builder;
    }
}

6.Open 包管理器控制台创建 table:Add-Migration InitialCreate update-database

7.Run 申请

结果: