ASP.NET?Core構(gòu)建OData查詢Restful?API
前言:
本文使用 .NET Core SDK 3.1 的版本。
OData 是 Open Data Protocol 的簡(jiǎn)寫(xiě),
OData 允許以簡(jiǎn)單和標(biāo)準(zhǔn)的方式創(chuàng)建和使用可查詢和互操作的 Restful API。
官方文檔訪問(wèn) OData - Basic Tutorial
創(chuàng)建 Web API 項(xiàng)目,并引入 OData 相關(guān)的 NuGet 包:
dotnet pack Microsoft.AspNetCore.OData -v 7.5.8
一、建構(gòu) OData 實(shí)體模型
在建構(gòu) OData 實(shí)體模型之前,需要先創(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 實(shí)體模型
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);
// 第一個(gè)參數(shù) 路由名稱,第二個(gè)參數(shù) 路由前綴,第三個(gè)參數(shù) 創(chuàng)建OData實(shí)體數(shù)據(jù)模型的方法
// 通過(guò)這個(gè)方式創(chuàng)建了與OData相關(guān)聯(lián)的路由
endpoints.MapODataRoute("odata", "odata", PersonModelBuilder.GetEdmModel());
});
}
三、OData 實(shí)現(xiàn) Restful API 查詢
創(chuàng)建一個(gè) PersonController 控制器,并繼承 ODataController。
給 Action 的特性增加上 [EnableQuery] 來(lái)表示當(dāng)前 API 是 OData 協(xié)議的方法,
在 Action 的入?yún)⒓由咸匦?[FromODataUri] 來(lái)表示當(dāng)前入?yún)?lái)自 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));
}
}
通過(guò)下面 Uri 訪問(wèn)查詢?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 通過(guò) $ 符號(hào)起始的參數(shù)來(lái)對(duì) Action 返回的結(jié)果進(jìn)行改造,進(jìn)行排序,字段的篩選等等功能。
我們?cè)L問(wèn) @odata.context 參數(shù)的 Value 這個(gè) Uri,我們可以看到該接口相關(guān)實(shí)體的詳細(xì)詳細(xì)。
通過(guò)下面 Uri 訪問(wèn)查詢某條數(shù)據(jù)的 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建構(gòu)OData實(shí)體模型實(shí)現(xiàn)Restful API查詢的詳細(xì)內(nèi)容,更多關(guān)于OData Restful API的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MAUI中實(shí)現(xiàn)構(gòu)建跨平臺(tái)原生控件
這篇文章介紹了MAUI中實(shí)現(xiàn)構(gòu)建跨平臺(tái)原生控件的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-02-02
asp.net core配置文件加載過(guò)程的深入了解
這篇文章主要給大家介紹了關(guān)于asp.net core配置文件加載過(guò)程的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12
asp.net在Repeater嵌套的Repeater中使用復(fù)選框詳解
這篇文章主要介紹了asp.net在Repeater嵌套的Repeater中使用復(fù)選框,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
asp.net XMLHttpRequest實(shí)現(xiàn)用戶注冊(cè)前的驗(yàn)證
用戶注冊(cè)前的驗(yàn)證,提高用戶體驗(yàn)。2009-10-10
MS SQL 實(shí)現(xiàn)驗(yàn)證字符串是否包含有大小寫(xiě)字母的功能
這篇文章主要介紹了MS SQL 實(shí)現(xiàn)驗(yàn)證字符串是否包含有大小寫(xiě)字母的功能的相關(guān)資料,這樣的功能通常應(yīng)用在字符串的復(fù)雜度需要的朋友可以參考下2016-11-11

