[翻译]创建ASP.NET WebApi RESTful 服务(9)

一旦成功的发布API后,使用者将依赖于你所提供的服务。但是变更总是无法避免的,因此谨慎的制定ASP.NET Web API的版本策略就变得非常重要。一般来说,新的功能需要无缝的接入,有时新老版本需要并行,以便给使用者足够的时间来进行迁移和配套的变更。设置,老的版本会一直持续被使用。

简单版本管理

假设我们现在对StudentsController进行修改,将GET方法中返回“FirstName” 和 “LastName”修改为返回“FullName”和 “CoursesDuration”。

最简单的方法就是新建一个类似于StudentsV2Controller的新服务。请留意V2,接下来将依赖这个引入管理策略。这种方法来自于Shawn Wildermuth的plural sight course文章。旧版本的服务返回的json应该是这样的:

   1:  [{
   2:      "id": 2,
   3:      "url": "http://localhost:8323/api/students/HasanAhmad",
   4:      "firstName": "Hasan",
   5:      "lastName": "Ahmad",
   6:      "gender": 0,
   7:      "enrollmentsCount": 4
   8:  },
   9:  {
  10:      "id": 3,
  11:      "url": "http://localhost:8323/api/students/MoatasemAhmad",
  12:      "firstName": "Moatasem",
  13:      "lastName": "Ahmad",
  14:      "gender": 0,
  15:      "enrollmentsCount": 4
  16:  }]

而新版本的返回如下:

   1:  [{
   2:      "id": 2,
   3:      "url": "http://localhost:8323/api/students/HasanAhmad",
   4:      "fullName": "Hasan Ahmad",
   5:      "gender": 0,
   6:      "enrollmentsCount": 4,
   7:      "coursesDuration": 13
   8:  },
   9:  {
  10:      "id": 3,
  11:      "url": "http://localhost:8323/api/students/MoatasemAhmad",
  12:      "fullName": "Moatasem Ahmad",
  13:      "gender": 0,
  14:      "enrollmentsCount": 4,
  15:      "coursesDuration": 16
  16:  }]

新版本的GET函数的实现为:

   1:  public IEnumerable<StudentV2BaseModel> Get(int page = 0, int pageSize = 10)
   2:      {
   3:          IQueryable<Student> query;
   4:   
   5:          query = TheRepository.GetAllStudentsWithEnrollments().OrderBy(c => c.LastName);
   6:   
   7:          var totalCount = query.Count();
   8:          var totalPages = Math.Ceiling((double)totalCount / pageSize);
   9:   
  10:          var urlHelper = new UrlHelper(Request);
  11:          var prevLink = page > 0 ? urlHelper.Link("Students", new { page = page - 1, pageSize = pageSize }) : "";
  12:          var nextLink = page < totalPages - 1 ? urlHelper.Link("Students", new { page = page + 1, pageSize = pageSize }) : "";
  13:   
  14:          var paginationHeader = new
  15:          {
  16:              TotalCount = totalCount,
  17:              TotalPages = totalPages,
  18:              PrevPageLink = prevLink,
  19:              NextPageLink = nextLink
  20:          };
  21:   
  22:          System.Web.HttpContext.Current.Response.Headers.Add("X-Pagination",
  23:          Newtonsoft.Json.JsonConvert.SerializeObject(paginationHeader));
  24:   
  25:          var results = query
  26:          .Skip(pageSize * page)
  27:          .Take(pageSize)
  28:          .ToList()
  29:          .Select(s => TheModelFactory.CreateV2Summary(s));
  30:   
  31:          return results;
  32:      }

StudentV2BaseModel和CreateV2Summary只是为了举例方便,实际可以根据需要是否要进行这样的修改或者无须修改。

具体的代码如下:

   1:  public class StudentV2BaseModel
   2:      {
   3:          public int Id { get; set; }
   4:          public string Url { get; set; }
   5:          public string FullName { get; set; }
   6:          public Data.Enums.Gender Gender { get; set; }
   7:          public int EnrollmentsCount { get; set; }
   8:          public double CoursesDuration { get; set; }
   9:      }
  10:   
  11:      public class ModelFactory
  12:      {
  13:          public StudentV2BaseModel CreateV2Summary(Student student)
  14:          {
  15:              return new StudentV2BaseModel()
  16:              {
  17:                  Url = _UrlHelper.Link("Students", new { userName = student.UserName }),
  18:                  Id = student.Id,
  19:                  FullName = string.Format("{0} {1}", student.FirstName, student.LastName),
  20:                  Gender = student.Gender,
  21:                  EnrollmentsCount = student.Enrollments.Count(),
  22:                  CoursesDuration = Math.Round(student.Enrollments.Sum(c => c.Course.Duration))
  23:              };
  24:          }
  25:      }

来源:http://bitoftech.net/2013/12/16/asp-net-web-api-versioning-strategy/

转载于:https://www.cnblogs.com/tukzer/p/3664153.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

研究生导师一般希望招什么样的研究生?

虽然还不是导师&#xff0c;但也在学校蹲了不少年头了&#xff0c;看着一级级研究生毕业奔赴各方&#xff0c;其实还是蛮有感触的。 各位同学很多在硕士期间回忆并不算好&#xff0c;其实就是从一开始没有搞明白一件事&#xff1a;导师招生为了什么&#xff0c;我们上研又为了什…

动态调用链接库(dll) 续

20141118 最近一周做了一个关于仓库管理&#xff0c;拣货任务分配的模块&#xff0c;其中涉及到刷卡自动打印领取任务的功能点。 技术点&#xff1a; C#调用C、delphi的动态链接库。动态链接库的调用方法不同。效果也不相同。 DLL位置&#xff1a;执行程序根目录下面 例&#x…

读写日志文件

日志为文本文件每列以制表符隔开 行以换行符隔开 本次示例简单实现如下相关功能&#xff1a;1.正写日志文本 最新的日志放后面2.倒写日志文本 最新的日志放前面3.读日志文本内容显示在Label4.读日志文本内容到DataTable 及 筛选后显示在GridView--------------------(以下操作并…

游戏策划试题(1)——摘自牛客网

对于游戏涉及的不多&#xff0c;但是对暴雪在各种经验贴和小道消息上还是有些了解的。涉猎一下 策划游戏之类 的面试知识&#xff0c;横向拓宽知识面&#xff0c;也有助于自己拓宽视野&#xff0c;看看这种游戏文案策划 作为一名运营策划&#xff0c;你觉得可通过哪些途径起到保…

Android Fragment应用实战

现在Fragment的应用真的是越来越广泛了&#xff0c;之前Android在3.0版本加入Fragment的时候&#xff0c;主要是为了解决Android Pad屏幕比较大&#xff0c;空间不能充分利用的问题&#xff0c;但现在即使只是在手机上&#xff0c;也有很多的场景可以运用到Fragment了&#xff…

初识树莓派

初识树莓派这一微型计算机&#xff0c;基本了解概念&#xff0c; 1、树莓派简介 Raspberry Pi(中文名为“树莓派”,简写为RPi&#xff0c;或者 RasPi/RPi)是为学生计算机编程教育而设计&#xff0c;只有信用卡大小的卡片式电脑&#xff0c;其系统基于Linux开发而来的。树莓派由…

ffmpeg抓取rtsp流并保存_详细解析RTSP框架和数据包分析(1)

0.引言 本文主要讲解RTSP框架和抓取RTSP数据包&#xff0c;进行详细分析。可以阅读以下几篇文章&#xff0c;能够帮助你更详细理解。 手把手搭建RTSP流媒体服务器 HLS实战之Wireshark抓包分析 HTTP实战之Wireshark抓包分析 1.RTSP协议简述 RTSP&#xff1a;Real Time Stream…

遍历窗体中所有控件的信息

public void TraverControl(Control Ctl) {   foreach (Control c in Ctl.Controls)  {     label1.Text "\n" "" c.Name "" "\n";     //用于显示窗体中包含的所有的控件名&#xff0c;首先显示的是最外层的控件  …

xshell 软件的窗口一直是置顶 调整为不置顶

突然感觉xshell 软件的窗口一直是置顶状态&#xff0c;点别的软件窗口点不过去&#xff0c; 搜索一下&#xff1a;微信的 alta是截图&#xff0c;和xshell这个冲突了。如果在xshell下按了这个&#xff0c;不知不觉就被置顶了。。。。。MMP 即这个意思&#xff1a; 如果要修改…

Linux下Vim工具常用命令

原文地址&#xff1a; http://www.cnblogs.com/lizhenghn/p/3675011.html 在linux下做开发&#xff0c;甚至是只做管理维护工作&#xff0c;也少不了Vim的使用。作为一个新手&#xff0c;我也是刚刚接触&#xff0c;本节将我日常使用或收集的Vim常用命令记录下来。 当然&#x…

整理加解释:以太网、快速以太网、千兆以太网和万兆以太网分别的概念和区分 大详解

一、以太网是什么 以太网(Ethernet)最早是由Xerox(施乐)公司创建的局域网组网规范&#xff0c;1980年DEC、Intel和Xeox三家公司联合开发了初版Ethernet规范—DIX 1.0&#xff0c;1982年这三家公司又推出了修改版本DIX 2.0&#xff0c;并将其提交给EEE 802工作组&#xff0c;经I…

zoj 1109 Language of FatMouse 解题报告

题目链接&#xff1a;http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId109 题目意思&#xff1a;给出一个mouse-english词典&#xff0c;问对于输入的mouse单词&#xff0c;能否在这个词典里找出对应的english&#xff0c;不能输出“eh” 这里用到map来做&#xf…

测试telnet安装成功 以及如何进入和退出telnet命令模式

telnet装好之后&#xff0c;测试。 输入&#xff1a;telnet www.baidu.com 80 出现如图提示是意思是&#xff1a; 正常连通。 然后 按 ctrl ] 进入telnet客户端命令模式&#xff0c;然后用quit退出。进入linux命令模式。

数据按时间拆开分批处理示例

我现在的问题是有一个大的事实表,已经有数十亿条数据,过来的临时表需要merge进去. 临时表的大小也不确定,可能上十亿也可能只有几百几千万而已. 如果直接让这两个表merge起来,则需要很大的内存来进行处理.所以我就想着把数据进行按时间拆分的处理,然后merge进去, 拆分的条件是如…

Linux E325: ATTENTION Found a swap file by the name “./.backu.sh.swp“

在vi编辑时遇到: E325: ATTENTION Found a swap file by the name "./.backu.sh.swp"错误代码。 原因是上次编辑的时候&#xff0c;卡了或者别的原因ctrl c强制退出了。下次进来Linux还是默认进入这个上次强制退出的文件&#xff0c;所以报错。 解决方…

python 函数的参数对应

作者&#xff1a;Vamei 出处&#xff1a;http://www.cnblogs.com/vamei 欢迎转载&#xff0c;也请保留这段声明。谢谢&#xff01; 我们已经接触过函数(function)的参数(arguments)传递。当时我们根据位置&#xff0c;传递对应的参数。我们将接触更多的参数传递方式。 回忆一下…

telnet远程登陆、mstsc远程控制、SSH之间的比较和区别

Telnet与远程桌面mstsc 一 演示 打开mstsc演示&#xff1a; 01 win r 输入mstsc 02 输入要远程的机子的用户名和密码 03 登录 04 连接开启了&#xff0c;如图即是通过win窗口操作远程机子。 以上是使用mstsc打开一个远程连接来通过windows窗口的方式来控制远程机器。 …

c语言中'.'与'-'的区别

记录学习c语言中遇见的问题。定义的结构体如果是指针&#xff0c;访问成员时就用->如果定义的是结构体变量&#xff0c;访问成员时就用.例如&#xff1a;struct AAA { int a; char b;};struct AAA q; 访问成员就用&#xff1a;q.a;struct AAA *p; 访问成员就用&#x…

Linux查看已经开放的端口,开放端口遇到防火墙的问题。

Linux查看已经开放的端口&#xff0c;开放端口&#xff0c;FirewallD is not running 查看已经开放的端口 firewall-cmd --list-all1 如果出现这种情况说明你的防火墙没有开: 则先把防火墙打开&#xff1a;systemctl start firewalld 扩展内容&#xff1a;. 查看firewalld状…

内核态(Kernel Mode)与用户态(User Mode)

内核态: CPU可以访问内存所有数据, 包括外围设备, 例如硬盘, 网卡. CPU也可以将自己从一个程序切换到另一个程序 用户态: 只能受限的访问内存, 且不允许访问外围设备. 占用CPU的能力被剥夺, CPU资源可以被其他程序获取 为什么要有用户态和内核态 由于需要限制不同的程序之间的访…