Versioning

为适应需求的变化以及兼容已有的API,需要创建新版本的API,一般有四种流行的版本化API的方法:

URI版本化
URI参数版本化
Accept header版本化
自定义header版本化

URI版本化

在这种方法中,版本信息变成了URI一部分。例如:

LinkedIn: https://api.linkedin.com/v1/people/~
Yahoo: https://social.yahooapis.com/v1/user/12345/profile
SalesForce: http://na1.salesforce.com/services/data/v26.0
Twitter: https://api.twitter.com/1.1/statuses/user_timeline.json
Twilio: https://api.twilio.com/2010-04-01/Accounts/{AccountSid}/Calls

URI版本化的方式,可以在URI中就可以展示版本信息,方便API的开发和测试,能够通过浏览器访问不同版本的API服务。但是,也会给client生命周期带来复杂性,比如,client保存了存在数据库中的用户资源的引用,为了切换到新版本的API,client必须对资源引用执行复杂的升级操作。

URI参数版本化

版本作为URI的参数,例如:http://api.example.org/users?v=2,用参数v表示版本二的API。此方式具有与URI版本化一样的优点和缺点。

Accept header版本化

此方式通过Accept header交互版本信息,因为header中包含了版本信息,所以多个版本的API可以使用同一个URI。为了传递版本信息,需要自定义资源类型,一般自定义的格式为:vnd.product_name.version+ suffix,vnd是自定义资源类型的起始点;product_name是资源的名称,用于区分其他资源类型;version是版本信息;suffix表示资源类型。例如application/vnd.quickpoll.v2+json。

因为不用更改整个API就可以访问资源,Accept header版本化方式变得越来越流行,但是这种方式使通过浏览器测试变得困难。

自定义header版本化

自定义header版本化,和Accept header方式一样,除了自定义header,而不是使用Accept header。因为HTTP规范提供了通过accept header的标准方式,所以此种方式没有被广泛的采用。

过期API的处理方式

当有新版本API发布时,会有一些API过期,但是不应该立即过期,应该再维护一段时间,在这段时间里提醒用户应该迁移到新版本的API。

Paging

REST api的消费者包括桌面应用、web应用、移动应用。出于对带宽和性能的考虑,都不应该直接返回一个大数据集,应该采用分页。有四种分页的方式:page number分页、limit offset分页、cursor-based分页、time-based分页。

page number分页

在这种风格中,用户指定他们需要的数据的页码。例如:

http://blog.example.com/posts?page=3
http://blog.example.com/posts?page=3&size=20
https://api.github.com/user/repos?page=2&per_page=100

server针对分页返回的响应可以像下面这样:

{
"data": [
... Blog Data
],
"totalPages": 9,
"currentPageNumber": 2,
"pageSize": 10,
"totalRecords": 90
}

limit offset分页

在这种风格中,用户指定limit和offset两个参数,限定他们需要的数据。例如:

http://blog.example.com/posts?limit=10&offset=30

cursor-based分页

在这种风格中,用户利用指针或者游标导航要访问的数据集。例如:用户发送一个http://blog.example.com/posts请求,server端返回:

{
"data" : [
... Blog data
],
"cursors" : {
"prev" : null,
"next" : "123asdf456iamcur"
}
}

用户再访问时,可使用如下URI:http://api.example.com/posts?cursor=123asdf456iamcur

time-based分页

在这种风格中,用户指定一个时间片用于检索数据。例如:

https://graph.facebook.com/me/feed?limit=25&until=1364587774
https://graph.facebook.com/me/feed?limit=25&since=1364849754

Sorting

Sorting让用户能够决定依据那列队数据集进行排序。一般的排序形式如下所示:

http://blog.example.com/posts?sortByDesc=createdDate&sortByAsc=title
http://blog.example.com/posts?sort=createdDate,desc&sort=title,asc
http://blog.example.com/posts?sort=-createdDate,title

Spring REST实践之Versioning,Paging和Sorting的更多相关文章

  1. WebGrid with filtering, paging and sorting 【转】

    WebGrid with filtering, paging and sorting by Jose M. Aguilar on April 24, 2012 in Web Development A ...

  2. Spring+MyBatis实践—MyBatis数据库访问

    关于spring整合mybatis的工程配置,已经在Spring+MyBatis实践—工程配置中全部详细列出.在此,记录一下几种通过MyBatis访问数据库的方式. 通过sqlSessionTempl ...

  3. Spring MVC 实践 - Component

    Spring MVC 实践 标签 : Java与Web Converter Spring MVC的数据绑定并非没有任何限制, 有案例表明: Spring在如何正确绑定数据方面是杂乱无章的. 比如: S ...

  4. Spring MVC 实践 - Base

    Spring MVC 实践 标签 : Java与Web Spring Web MVC Spring-Web-MVC是一种基于请求驱动的轻量级Web-MVC设计模式框架, Spring MVC使用MVC ...

  5. Spring Boot实践——Spring AOP实现之动态代理

    Spring AOP 介绍 AOP的介绍可以查看 Spring Boot实践——AOP实现 与AspectJ的静态代理不同,Spring AOP使用的动态代理,所谓的动态代理就是说AOP框架不会去修改 ...

  6. Spring Boot实践——AOP实现

    借鉴:http://www.cnblogs.com/xrq730/p/4919025.html     https://blog.csdn.net/zhaokejin521/article/detai ...

  7. Spring Boot 实践 :Spring Boot + MyBatis

    Spring Boot 实践系列,Spring Boot + MyBatis . 目的 将 MyBatis 与 Spring Boot 应用程序一起使用来访问数据库. 本次使用的Library spr ...

  8. Spring Batch实践

    Spring Batch在大型企业中的最佳实践 在大型企业中,由于业务复杂.数据量大.数据格式不同.数据交互格式繁杂,并非所有的操作都能通过交互界面进行处理.而有一些操作需要定期读取大批量的数据,然后 ...

  9. Spring REST实践之Spring Boot

    Spring Boot基本描述 可以利用http://start.spring.io网站的进行Spring Boot的初始化构建.这个初始化构建器允许你输入工程基本信息.挑选工程支持的功能,最后会生成 ...

随机推荐

  1. 工作流Activiti5流程变量 任务变量 setVariables 跟 setVariablesLocal区别

    工作流Activiti5流程变量 任务变量 setVariables 和 setVariablesLocal区别 因为网上的资料比较少.结合源码把相关API写下来. 设置流程级别变量: runtime ...

  2. 在Linux系统中如何装rpm,deb,tar.gz,tar.bz2,apt,bin 格式的文件

    首先安装 系统自带的 alien 包 :终端 -su-输入密码 -进入ROOT 用户 - sudo apt-get install alien 这样 alien 包 就装上去了 !(if alien  ...

  3. Dispatcher

    Dispatcher是guava EventBus的事件分发器. Dispatcher是抽象类, 抽象方法: abstract void dispatch(Object event, Iterator ...

  4. 【C++】非原创|统计代码覆盖率(一:C++)

    也是转别人的,因为我c++好菜好菜啊... http://blog.chinaunix.net/uid-23741326-id-3316943.html c++跟C基本是一样的,统计覆盖率,需要生成g ...

  5. java 代码如何生成 chm

    由于要把一个框架的东西打成 chm, 今天在网上找了几篇文章 http://blog.sina.com.cn/s/blog_5d31611a0100gqwp.html 李顺利 首先第一步,从eclip ...

  6. 【转】 Linux Shell 命令--rename

    重命名文件,经常用到mv命令,批量重命名文件rename是最好的选择,Linux的rename 命令有两个版本,一个是C语言版本的,一个是Perl语言版本的,判断方法:输入man rename 看到第 ...

  7. Android:控件WebView显示网页 -摘自网络

    WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用. webview有两个方法:setWebChromeClient 和 setWebClient setWebClient:主要 ...

  8. 【转】从零开始编写自己的C#框架(7)——需求分析

    转自:http://www.cnblogs.com/EmptyFS/p/3653934.html 本章内容虽然叫“需求分析”,实际上关于具体的需求分析操作步骤并没有深入去写,因为细化的话那将是一本厚厚 ...

  9. T-SQL游标

    游标是面向行的,它会使开发人员变懒,懒得去想用面向集合的查询方式实现某些功能. 在性能上,游标会迟更多的内存,减少可用的并发,占用带宽,锁定资源,当然还有更多的代码量. 用一个比喻来说明为什么游标会占 ...

  10. SQL Server 字符串函数

    字符串函数 在开发T-SQL时,经常会需要对字符串进行各种各样的操作,下面介绍常用的字符串函数. 1.获取字符的ASCII码 ASCII ASCII码是对字符的标准编码.要获取字符的ASCII码就可以 ...