ASP.NET Core构建OData查询Restful API

ASP.NET Core构建OData查询Restful API

目录

前言:

一、建构 OData 实体模型

二、配置 OData 中间件

三、OData 实现 Restful API 查询

参考文档

前言:

本文使用 .NET Core SDK 3.1 的版本。

OData 是 Open Data Protocol 的简写,

OData 允许以简单和标准的方式创建和使用可查询和互操作的 Restful API。

官方文档访问 OData - Basic Tutorial

创建 Web API 项目,并引入 OData 相关的 NuGet 包:

dotnet pack Microsoft.AspNetCore.OData -v 7.5.8 一、建构 OData 实体模型

在建构 OData 实体模型之前,需要先创建相关的 DTO

public class Person { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } }

随后建构 OData 实体模型

public static class PersonModelBuilder { public static IEdmModel GetEdmModel() { var oDataBuilder = new ODataConventionModelBuilder(); oDataBuilder.EntitySet<Person>("Person"); return oDataBuilder.GetEdmModel(); } } 二、配置 OData 中间件

配置 OData 服务

public void ConfigureServices(IServiceCollection services) { // ...... services.AddOData(); }

配置 OData 中间件

public void Configure(IApplicationBuilder app, IWebHostEnvironment env) { app.UseRouting(); app.UseEndpoints(endpoints => { endpoints.Select().Filter().OrderBy().Count().MaxTop(10); // 第一个参数 路由名称,第二个参数 路由前缀,第三个参数 创建OData实体数据模型的方法 // 通过这个方式创建了与OData相关联的路由 endpoints.MapODataRoute("odata", "odata", PersonModelBuilder.GetEdmModel()); }); } 三、OData 实现 Restful API 查询

创建一个 PersonController 控制器,并继承 ODataController。

给 Action 的特性增加上 [EnableQuery] 来表示当前 API 是 OData 协议的方法,

在 Action 的入参加上特性 [FromODataUri] 来表示当前入参来自 OData 格式的 Uri 中。

public class PersonController : ODataController { private static readonly List<Person> PEOPLE = new List<Person> { new Person { Id = 1, Name = "张三", Age = 18 }, new Person { Id = 2, Name = "李四", Age = 19 }, new Person { Id = 3, Name = "王五", Age = 20 }, new Person { Id = 4, Name = "赵六", Age = 21 }, }; [HttpGet, EnableQuery] public ActionResult Get() { var people = PEOPLE; return Ok(people); } [HttpGet, EnableQuery] public IActionResult Get([FromODataUri] int key) { var people = PEOPLE; return Ok(people.FirstOrDefault(b => b.Id == key)); } }

通过下面 Uri 访问查询全部数据的 API,

http://localhost:5000/odata/person?$select=name,age&$orderby=age desc&$count=true&$top=2&$skip=2

我们先看结果,我们可以得到如下 JSON

{ "@odata.context": "http://localhost:5000/odata/$metadata#Person(Name,Age)", "@odata.count": 4, "value": [ { "Name": "李四", "Age": 19 }, { "Name": "张三", "Age": 18 } ] }

得到的结果不难看出,OData 查询 API 的 Uri 通过 $ 符号起始的参数来对 Action 返回的结果进行改造,进行排序,字段的筛选等等功能。
我们访问 @odata.context 参数的 Value 这个 Uri,我们可以看到该接口相关实体的详细详细。

通过下面 Uri 访问查询某条数据的 API,

http://localhost:5000/odata/person(1)

我们可以得到如下 JSON

{ "@odata.context": "http://localhost:5000/odata/$metadata#Person/$entity", "Id": 1, "Name": "张三", "Age": 18 } 参考文档

OData - Basic Tutorial

以上就是ASP.NET Core建构OData实体模型实现Restful API查询的详细内容,更多关于OData Restful API的资料请关注易知道(ezd.cc)其它相关文章!

推荐阅读

    学习写字楼新选择6000元主流配置

    学习写字楼新选择6000元主流配置,,这种配置需要考虑双核心的办公和娱乐平台,充分考虑办公室的办公需求和娱乐需求,以约6000元的预算和cost-e

    酷睿I7 配置

    酷睿I7 配置,配置,玩家国度啦华硕 Rampage II Extreme(3800元)如果米不够,也可以把Extreme改为Gene,不过是小板内存推荐金士顿6G DDR3 2000骇

    提高3A四核羿龙II游戏配置的性能

    提高3A四核羿龙II游戏配置的性能,,以节能环保为主题的IT产业,目前3A低端平台处理器、主板芯片组、独立开发卡性能突出,特别是在与AMD的处理

    opporeno8参数配置及价格

    opporeno8参数配置及价格,面部,亿元,Oppo的荣誉2020年1月4日,接近屏幕关闭传感器是否支持双卡:支持oppor11splus什么时候上市的Oppo R11S P

    查看配置:酷睿i3530集展示办公平台

    查看配置:酷睿i3530集展示办公平台,,由于时间和精力的关系,我们不可能对所有的配置进行评论,希望我们能理解,我希望我们的评论能在那些需要帮

    3500元超额值学生娱乐结构的优化配置

    3500元超额值学生娱乐结构的优化配置,,作为一个DIY的主流用户领域的学生,每个用户51学生攒机的高峰。因为学生用户没有稳定的收入来源,攒机