博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ABP官方文档翻译 5.3 OData集成
阅读量:7064 次
发布时间:2019-06-28

本文共 5605 字,大约阅读时间需要 18 分钟。

OData集成

 

介绍

   OData定义为“一种开放协议允许使用简单或标准的方式创建和消费可查询和可交互的RESTful APIs”。你可以在ABP中使用OData。 nuget包简化了它的使用。

安装

安装Nuget包

  首先需要在我们的WebApi工程中安装Abp.OData nuget包:

Install-Package Abp.Web.Api.OData

设置模块依赖

  我们的模块中需要设置AbpApiODataModule的依赖。示例:

[DependsOn(typeof(AbpWebApiODataModule))]public class MyProjectWebApiModule : AbpModule{    ...}

  参见了解模块依赖。

配置实体

  OData需要声明可以用做为OData资源的实体。我们应该在模块的PreInitialize方法中定义,如下所示:

[DependsOn(typeof(AbpWebApiODataModule))]public class MyProjectWebApiModule : AbpModule{    public override void PreInitialize()    {        var builder = Configuration.Modules.AbpWebApiOData().ODataModelBuilder;        //Configure your entities here...        builder.EntitySet
("Persons"); } ...}

  这里,我们获取ODataModelBuilder引用并设置Person实体。类似的,你可以使用EntitySet添加其他的实体。参见了解更多关于builder的信息。

创建控制器

  Abp.Web.Api.OData nuget包包含AbpODataEntityController基类(扩展自标准的ODataControler)用来方便的创建你自己的控制器。创建Person实体OData终结点的实例如下:

public class PersonsController : AbpODataEntityController
{ public PersonsController(IRepository
repository) : base(repository) { }}

  非常简单!AbpODataEntityController的所有方法都是virtual的。这意味着,你可以重写Get、POST、Put、Patch、Delete和其他actions并添加自己的逻辑。

配置

  Abp.Web.Api.OData使用常规配置自动调用HttpConfiguration.MapODataServiceRoute方法。如果需要,你可以设置Configuration.Modules.AbpWebApiOData().MapAction映射到自己的OData路径。

示例

  这里,有一些请求上面定义的控制器的例子。假定应用运行在http://localhost:61482。我们将展示一些基本要素。因为OData是一个标准协议,你可以轻松的在网上找到更多高级的例子。

获取实体列表

  获取所有的people。

Request

GET http://localhost:61842/odata/Persons

Response

{  "@odata.context":"http://localhost:61842/odata/$metadata#Persons","value":[    {      "Name":"Douglas Adams","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":1    },{      "Name":"John Nash","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":2    }  ]}

获取单个实体

  获取Id=2的person。

Request

GET http://localhost:61842/odata/Persons(2)

Response

{  "@odata.context":"http://localhost:61842/odata/$metadata#Persons/$entity","Name":"John Nash","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":2}

使用导航属性获取单个实体

  获取Id=1的person并包含他的电话号码。

Request

GET http://localhost:61842/odata/Persons(1)?$expand=Phones

Response

{  "@odata.context":"http://localhost:61842/odata/$metadata#Persons/$entity","Name":"Douglas Adams","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":1,"Phones":[    {      "PersonId":1,"Type":"Mobile","Number":"4242424242","CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":1    },{      "PersonId":1,"Type":"Mobile","Number":"2424242424","CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":2    }  ]}

查询

  这里,一个更高级的查询包含过滤、排序并获取前两个结果。

Request

GET http://localhost:61842/odata/Persons?$filter=Name eq 'Douglas Adams'&$orderby=CreationTime&$top=2

Response

{  "@odata.context":"http://localhost:61842/odata/$metadata#Persons","value":[    {      "Name":"Douglas Adams","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2015-11-07T20:12:39.363+03:00","CreatorUserId":null,"Id":1    },{      "Name":"Douglas Adams","IsDeleted":false,"DeleterUserId":null,"DeletionTime":null,"LastModificationTime":null,"LastModifierUserId":null,"CreationTime":"2016-01-12T20:29:03+02:00","CreatorUserId":null,"Id":3    }  ]}

  OData支持分页,排序,过滤,投射等。参见了解更多信息。

创建新实体

  在这个例子中,我们创建一个新person。

Request

POST http://localhost:61842/odata/Persons{    Name: "Galileo Galilei"}

  这里,“Content-Type”头为"application/json"。

Response

{  "@odata.context": "http://localhost:61842/odata/$metadata#Persons/$entity",  "Name": "Galileo Galilei",  "IsDeleted": false,  "DeleterUserId": null,  "DeletionTime": null,  "LastModificationTime": null,  "LastModifierUserId": null,  "CreationTime": "2016-01-12T20:36:04.1628263+02:00",  "CreatorUserId": null,  "Id": 4}

  如果我们再一次获取这个列表,我们就会看见这个新的person。我们也可以update或delete一个存在的实体,OData是支持的。

获取元数据

  我们可以获取实体的元数据,如在本例中所示。

Request

GET http://localhost:61842/odata/$metadata

Response

  元数据用来研究这个服务。

示例工程

  你可以在这里获取示例工程的源代码:

 

转载于:https://www.cnblogs.com/xajh/p/7041680.html

你可能感兴趣的文章
JAVA UUID 生成唯一标识
查看>>
spring学习笔记(4)依赖注入详解
查看>>
菜鸟学自动化测试(五)-----selenium命令之定位页面元素
查看>>
【SICP练习】64 练习2.35
查看>>
PSK星座对象(constellation.cc)
查看>>
Linux链接脚本学习--lds
查看>>
Android将list数据通过LitePal保存到本地(集合保存到本地)
查看>>
hdu 1285 确定比赛名次
查看>>
Eureka微服务实战-服务提供者
查看>>
简单的原生ajax
查看>>
h5开发坑点小总结
查看>>
几分钟内提升技能的8个 JavaScript 方法!
查看>>
mac显示隐藏文件
查看>>
Android 插件化原理-好文收集(陆续中。。。)
查看>>
双亲委派模型与Tomcat类加载架构
查看>>
Highcharts tooltip显示数量和百分比
查看>>
小程序兼容iphoneX(齐刘海)代码,mpvue的写法
查看>>
小米设备怎么不ROOT激活Xposed框架的步骤
查看>>
Vue Router
查看>>
你所听到的技术原理、技术本质到底是什么?
查看>>