文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

ASP.NET Core怎么构建OData查询Restful API

2023-06-30 10:49

关注

这篇文章主要讲解了“ASP.NET Core怎么构建OData查询Restful API”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ASP.NET Core怎么构建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  }

感谢各位的阅读,以上就是“ASP.NET Core怎么构建OData查询Restful API”的内容了,经过本文的学习后,相信大家对ASP.NET Core怎么构建OData查询Restful API这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯