出处:http://www.cnblogs.com/liuzhendong/p/4233380.html

让Asp.Net WebAPI支持OData后,就能支持在url中直接输入排序,过滤条件了。

一.创建Asp.Net WebAPI项目:

二.使用NuGet安装Asp.Net WebAPI 2.2和OData包

三.修改WebAPIConfig.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web.Http;
using System.Net.Http.Formatting;
using System.Net.Configuration; namespace ProjectManagementWebAppV3
{
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
// Web API configuration and services // Web API routes
config.MapHttpAttributeRoutes(); config.Routes.MapHttpRoute(
name: "DefaultApi",
routeTemplate: "api/{controller}/{id}",
defaults: new { id = RouteParameter.Optional }
); config.Formatters.JsonFormatter.AddQueryStringMapping("$format", "json", "application/json");
config.Formatters.XmlFormatter.AddQueryStringMapping("$format", "xml", "application/xml"); config.EnableQuerySupport(); }
}
}

主要添加红色粗体字:config.EnableQuerySupport(); 
这是存在于System.Web.Http.OData.dll里的一个静态扩展方法,表示在项目中启用OData查询。

四.修改ProjectManagementControler.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using ProjectManagementWebAppV3.Models;
using System.Web.Http.OData.Query;
using ProjectManagementWebAppV3.Utility;
using System.Data;
using System.Data.SqlClient;
using System.Configuration; namespace ProjectManagementWebAppV3.Controllers
{
public class ProjectManagentController : ApiController
{
private static List<ProjectModel> projectList = null; static ProjectManagentController()
{
projectList = new List<ProjectModel>
{
new ProjectModel { id=1, ProjectName = "项目1", MileStones = "2013年1月开始,3月组装测试,6月功能测试,10月上线;" },
new ProjectModel { id=2, ProjectName = "项目2", MileStones = "2013年3月开始,6月组装测试,9月功能测试,12月上线;" },
new ProjectModel { id=3, ProjectName = "项目3", MileStones = "2013年7月开始,9月组装测试,11月功能测试,12月上线;" }
};
}
/// <summary>
/// 获取全部数据
/// </summary>
/// <returns></returns>
[Queryable(AllowedQueryOptions = AllowedQueryOptions.All)]
public List<ProjectModel> Get()
{
return projectList;
}
}
}

主要在Get方法上增加红色粗体字的属性:[Queryable(AllowedQueryOptions = AllowedQueryOptions.All)]

从下表可以看到,AllowedQueryOptions枚举支持的操作符号列表:

    public enum AllowedQueryOptions
{
None = 0,
Filter = 1,
Expand = 2,
Select = 4,
OrderBy = 8,
Top = 16,
Skip = 32,
InlineCount = 64,
Supported = 127,
Format = 128,
SkipToken = 256,
All = 511,
}

五.运行示例:

表示返回id小于10,并按id倒序的前2条数据。

这看起来并不难,但好处是,它们都不需要写任何代码,也不用写存储过程,不用写任何一个特别的逻辑去支持这些功能,全部都由OData框架来提供的。

也就是说,用了OData,为搜索、过滤、分页的时候提供了一个很省事的选项。

六.代码下载:

packages和bin目录太大无法上传,只把项目代码打了个包。

代码下载

最新文章

  1. java 深入技术四(Set)
  2. HTML 播放器 写给自己
  3. 主机使用代理上网,虚拟机Linux如何连外网
  4. linux ssh config
  5. map的用法
  6. javascript大神修炼记(7)——OOP思想(多态)
  7. 让/etc/profile文件修改后立即生效(转)
  8. 51nod 1314 定位系统
  9. visual studio 2012 update3
  10. 了解常见的 Azure 灾难
  11. sql 针对多个id或名称的分割和组合
  12. Norm 数据库操作竟然可以如此简单
  13. PHP 字符串转 bigint 型md5
  14. 3.3 for 循环
  15. Prometheus运⾏框架介绍
  16. 【建图+拓扑判环】BZOJ3953: [WF2013]Self-Assembly
  17. input密码框输入后设置显示为星号或其他样式
  18. 浅谈Web开发中的定时任务
  19. Oracle的 listagg() WITHIN GROUP ()函数使用
  20. redis实战 -- python知识散记

热门文章

  1. Python 缓存机制与 functools.lru_cache(zz)
  2. hasura graphql subscriptions 使用
  3. 文档内容类似项处理-Shingling
  4. macOS -- 如何通过终端开启/关闭SSH
  5. .NET泛型解析(上)
  6. CentOS 6.5 下HeartBeat的安装与配置
  7. emacs之配置5,窗口位置和大小
  8. HDU 1717 小数化分数2(最大公约数)
  9. 【ZZ】国外大型网站使用到编程语言 | 菜鸟教程
  10. HDU 1043 八数码问题的多种解法