網(wǎng)站首頁 編程語言 正文
前言:
本文使用 .NET Core SDK 3.1 的版本。
OData 是 Open Data Protocol 的簡寫,
OData 允許以簡單和標(biāo)準(zhǔn)的方式創(chuàng)建和使用可查詢和互操作的 Restful API。
官方文檔訪問 OData - Basic Tutorial
創(chuàng)建 Web API 項目,并引入 OData 相關(guān)的 NuGet 包:
dotnet pack Microsoft.AspNetCore.OData -v 7.5.8
一、建構(gòu) OData 實體模型
在建構(gòu) OData 實體模型之前,需要先創(chuàng)建相關(guān)的 DTO
public class Person { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } }
隨后建構(gòu) OData 實體模型
public static class PersonModelBuilder { public static IEdmModel GetEdmModel() { var oDataBuilder = new ODataConventionModelBuilder(); oDataBuilder.EntitySet<Person>("Person"); return oDataBuilder.GetEdmModel(); } }
二、配置 OData 中間件
配置 OData 服務(wù)
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); // 第一個參數(shù) 路由名稱,第二個參數(shù) 路由前綴,第三個參數(shù) 創(chuàng)建OData實體數(shù)據(jù)模型的方法 // 通過這個方式創(chuàng)建了與OData相關(guān)聯(lián)的路由 endpoints.MapODataRoute("odata", "odata", PersonModelBuilder.GetEdmModel()); }); }
三、OData 實現(xiàn) Restful API 查詢
創(chuàng)建一個 PersonController 控制器,并繼承 ODataController。
給 Action 的特性增加上 [EnableQuery]
來表示當(dāng)前 API 是 OData 協(xié)議的方法,
在 Action 的入?yún)⒓由咸匦?[FromODataUri]
來表示當(dāng)前入?yún)碜?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 訪問查詢?nèi)繑?shù)據(jù)的 API,
http://localhost:5000/odata/person?$select=name,age&$orderby=age desc&$count=true&$top=2&$skip=2
我們先看結(jié)果,我們可以得到如下 JSON
{ "@odata.context": "http://localhost:5000/odata/$metadata#Person(Name,Age)", "@odata.count": 4, "value": [ { "Name": "李四", "Age": 19 }, { "Name": "張三", "Age": 18 } ] }
得到的結(jié)果不難看出,OData 查詢 API 的 Uri 通過 $
符號起始的參數(shù)來對 Action 返回的結(jié)果進(jìn)行改造,進(jìn)行排序,字段的篩選等等功能。
我們訪問 @odata.context 參數(shù)的 Value 這個 Uri,我們可以看到該接口相關(guān)實體的詳細(xì)詳細(xì)。
通過下面 Uri 訪問查詢某條數(shù)據(jù)的 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
原文鏈接:https://blog.csdn.net/Upgrader/article/details/117933639
相關(guān)推薦
- 2023-06-05 關(guān)于C++的.cpp文件運(yùn)行全過程_C 語言
- 2022-06-16 react?可拖拽進(jìn)度條的實現(xiàn)_React
- 2022-05-01 你需要掌握的20個Python常用技巧_python
- 2022-01-29 調(diào)用存儲命令:將sqlserver表中的數(shù)據(jù)導(dǎo)出sql語句或生成insert into語句
- 2022-03-26 .Net?6中的PeriodTimer介紹_ASP.NET
- 2022-11-13 Redis中HyperLogLog的使用詳情_Redis
- 2022-09-03 Pycharm中運(yùn)行程序在Python?console中執(zhí)行,不是直接Run問題_python
- 2022-12-07 C++?基本數(shù)據(jù)類型中int、long等整數(shù)類型取值范圍及原理分析_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支