开放数据协议 (OData) 是一种用于 web 的数据访问协议 OData 提供统一的方式来查询和操作数据集通过 CRUD 操作 (创建、 读取、 更新和删除) 以下以asp .net为例作讲解
引用
Microsoft.AspNet.WebApi Microsoft.AspNet.WebApi.Client Microsoft.AspNet.WebApi.Cors Microsoft.AspNet.WebApi.WebHost在App_Start中添加类文件WebApiConfig.cs
public class WebApiConfig { public static void Register(HttpConfiguration configuration) { configuration.Routes.MapHttpRoute("API Default", "api/{controller}/{id}", new { id = RouteParameter.Optional }); } }修改Global.asax.cs文件,注入WebApiConfig
//在注册默认路由之前 before registering the default Web Application route as that would otherwise take precedence. WebApiConfig.Register(GlobalConfiguration.Configuration); RouteConfig.RegisterRoutes(RouteTable.Routes);https://stackoverflow.com/questions/11990036/how-to-add-web-api-to-an-existing-asp-net-mvc-4-web-application-project
分Server和Client两部分
配置
ODataModelBuilder builder = new ODataConventionModelBuilder(); //多个实体,不能重名 builder.EntitySet<Product>("Products"); builder.EntitySet<Supplier>("Suppliers"); //定义自定义方法 builder.Function("GetSalesTaxRate") .Returns<double>() .Parameter<int>("PostalCode"); configuration.MapODataServiceRoute( routeName: "ODataRoute", routePrefix: null, model: builder.GetEdmModel());实现相关接口 完成之后,运行or发布Server,保证能够访问
新建控制台(任意客户端) 安装工具(需要重启VS) 新建服务代理 配置服务代理:打开.tt文件,如图所示,有一个MetadataDocumentUri参数,配置为Server的网址,保存之后,会自动生成服务代理(更新也是这个步骤) 调用服务
string serviceUri = "http://localhost:5003/"; var container = new Default.Container(new Uri(serviceUri)); //调用自定义方法 var rate = container.GetSalesTaxRate(1);https://github.com/zLulus/NotePractice/tree/dev3/Website/DotNetFramework/NotePracticehttps://github.com/zLulus/NotePractice/tree/dev3/Website/DotNetFramework/OData.Client
https://docs.microsoft.com/zh-cn/aspnet/web-api/overview/odata-support-in-aspnet-web-api/odata-v4/create-an-odata-v4-endpointhttps://docs.microsoft.com/zh-cn/aspnet/web-api/overview/odata-support-in-aspnet-web-api/odata-v4/create-an-odata-v4-client-apphttp://www.cnblogs.com/bluedoctor/p/4384659.html
转载于:https://www.cnblogs.com/Lulus/p/9726388.html
相关资源:《OData入门教程》