webapi 版本控制
一、问题
软件开发过程中,常常会需要变更以前的接口,添加或删除接口请求字段,接口字段校验、甚至是变更请求/返回字段名称,如果强制要求所有客户端跟着一起升级代价太大。如果接口从一开始就考虑到了版本的设计,那么做到平滑升级就很容易了。
二、版本控制方式
1、利用url传入版本
以@RequestMapping("/api")controller为例:
在路径里传入版本号:
优点:可以做到大版本切换,路由下的所有接口同时更新
缺点:实际中往往不会涉及很多接口同时升级,并且往往难以控制不同接口的版本(版本管理容易混乱)
/**
* http://localhost:8090/api/v1/getUser/111
* {"userId":111,"userName":"小明"}
*
* @param userId
* @return
*/
@RequestMapping(value = "/v1/getUser/{userId}")
public GetUserV1Response getUserInfoV1(@PathVariable("userId") Integer userId) {
return new GetUserV1Response(userId, "小明");
}
通过参数传入(POST 或 GET)
可以单独控制,注意version不存在和乱传值的处理
/**
* http://localhost:8090/api/getUser/111?version=v1
* {"userId":111,"userName":"小明"}
* <p>
* http://localhost:8090/api/getUser/111?version=v2
* {"userId":111,"userName":"小明","notes":"version 2"}
*
* @param userId
* @return
*/
@RequestMapping(value = "/getUser/{userId}")
public Object getUserInfo(@PathVariable("userId") Integer userId, @RequestParam("version") String version) {
if ("v1".equals(version)) {
return new GetUserV1Response(userId, "小明");
}
return new GetUserV2Response(userId, "小明", "version 2");
}
2、利用request header
以@RequestMapping("/api2")controller为例:
header设置在Controller或Action上都可以,设置在Controller上,控制所有Action的版本,设置在Action上,单独控制一个Action的版本
@RestController
@RequestMapping(value = "/api2")
public class ApiVersionHeaderDemoController {
@Autowired
private HttpServletRequest request; //request header
@RequestMapping(value = "/getUserById/{userId}", headers = "version=v2")
public Object getUserInfo(@PathVariable("userId") Integer userId) {return new GetUserV2Response(userId, "小明", "version 2");
}
}
对应版本:
不支持的版本:

3、利用content type
利用自定义请求的Content-Type来控制版本:
/**
* 请求的是 application/vnd.apiversioncontrol.v1+json
* 返回的是 application/json;charset=UTF-8
* v1 是api版本
*
* @param userId
* @return
*/
@RequestMapping(value = "/getUserById/{userId}", consumes = "application/vnd.apiversioncontrol.v1+json")
public Object getUserInfoV11(@PathVariable("userId") Integer userId) {
return new GetUserV2Response(userId, "小明", "version 2");
}
返回的是Content-Type:application/json;charset=UTF-8(不指定produces,默认是application/json;charset=UTF-8)

同时指定request和response的Content-Type为:application/vnd.apiversioncontrol.v2+json
/**
* 请求、返回Content-Type都是 application/vnd.apiversioncontrol.v1+json
* v1 :为api版本
*
* @param userId
* @return
*/
@RequestMapping(value = "/getUserById/{userId}", consumes = "application/vnd.apiversioncontrol.v2+json", produces = "application/vnd.apiversioncontrol.v2+json")
public Object getUserInfoV12(@PathVariable("userId") Integer userId) {
return new GetUserV2Response(userId, "小明", "version 2");
}

同时指定request和response的Content-Type为:application/vnd.apiversioncontrol+json;version=v2
/**
* 请求、返回Content-Type都是 application/vnd.apiversioncontrol+json;version=v2
* v2 :为api版本
*
* @param userId
* @return
*/
@RequestMapping(value = "/getUserById/{userId}", consumes = "application/vnd.apiversioncontrol+json;version=v2", produces = "application/vnd.apiversioncontrol+json;version=v2")
public Object getUserInfoV2(@PathVariable("userId") Integer userId) {
return new GetUserV2Response(userId, "小明", "version 2");
}

三、注解实现
注解来实现:SpingMVC框架实现restfull接口的版本控制
webapi 版本控制的更多相关文章
- ASP.NET Core WebApi版本控制
前言: 在日常项目开发中,随着项目需求不断的累加.不断的迭代:项目服务接口需要向下兼容历史版本:前些时候就因为Api接口为做版本管理导致接口对低版本兼容处理不友好. 最近就像了解下如何实现WebApi ...
- 电商系统架构总结4(webapi 版本控制)
为了 顺利迭代升级,web api 在维护过程是不断升级的,但用户是不能强迫他们每次都跟随你去升级,这样会让用户不胜其烦.为了保证不同版本的客户端能同时兼容,在web api接口上加入版本控制就很有必 ...
- Asp.net WebApi版本控制
有关web api的版本控制网上有很多,如Web API 版本控制的几种方式 Web API 版本化的介绍 但是具体的code并不多,或者说可以run的demo 不多. 版本控制如果项目一开始还好做关 ...
- Asp.Net.Core WebApi 版本控制
前言 在后端Api的开发过程中,无法避免的会遇到接口迭代的过程,如何保证新老接口的共存和接口的向前的兼容呢,这时候就需要对Api进行版本的控制,那如何优雅的控制Api的版本呢? 开始 Microsof ...
- Owin WebApi版本控制
public class WebApiControllerSelector : IHttpControllerSelector { private const string NamespaceKey ...
- ASP.Net Core WebApi几种版本控制对比
版本控制的好处: (1)助于及时推出功能, 而不会破坏现有系统. (2)它还可以帮助为选定的客户提供额外的功能. API 版本控制可以采用不同的方式进行控制,方法如下: (1)在 URL 中追加版本或 ...
- WebApi的版本控制
using System; using System.Collections.Generic; using System.Linq; using System.Web.Http; using Sy ...
- Net Core WebApi几种版本控制对比
Net Core WebApi几种版本控制对比 一.版本控制的好处: (1)有助于及时推出功能, 而不会破坏现有系统. (2)它还可以帮助为选定的客户提供额外的功能. API 版本控制可以采用不同的方 ...
- .NetCore WebApi —— Swagger版本控制
目录: .NetCore WebApi——Swagger简单配置 .NetCore WebApi——基于JWT的简单身份认证与授权(Swagger) .NetCore WebApi —— Swagge ...
随机推荐
- C语言数组的概念
在<C语言数据输出大汇总以及轻量进阶>一节中我们举了一个例子,是输出一个 4×4 的整数矩阵,代码如下: #include <stdio.h> #include <std ...
- map重写比较器
结构体作为map的key或放入set中,需要重载<运算符,如下: typedef struct tagRoadKey { int m_i32Type; int m_i32Scale; bool ...
- angular4 在页面跳转的时候传递多个参数到新页面
页面跳转 router.navigate //单一参数: this.router.navigate(['/detail',id]); //多个参数: this.router.navigate(['/d ...
- CentOS设置密码复杂度及过期时间等
我们在使用linux系统设置密码的时候,经常遇到这样的问题,系统提示:您的密码太简单,或者您的密码是字典的一部分.那么系统是如何实现对用户的密码的复杂度的检查的呢? 系统对密码的控制是有两部分(我知道 ...
- CSS 中 BEM命名方式
BEM的意思就是块(block).元素(element).修饰符(modifier),是一种CSS Class 命名方法. 类似于: .block{} .block__element{} .block ...
- Macbook pro 13" compile Apollo 2.5
STEPS: 0. Install Homebrew 1. Install 'Docker for Mac 18.03+',配置CPUs (n个CPUs,Bazel开n个线程编译), Memory ...
- SQL Server 常用分页SQL(转)
发现网上好多都是错的.网上经常查到的那个Top Not in 或者Max 大部分都不实用,很多都忽略了Order和性能问题.为此上网查了查,顺带把2000和2012版本的也补上了. 先说说网上常见SQ ...
- java基础03变量和基本数据类型
package cn.bdqn.test; /** * * @author 小豆腐 * * 变量:会变化的量?? * 一个数据在内存中存储空间的表示!在运行期间可以动态改变! * * 关键字:在jav ...
- Robberies---hdu2955(概率dp,01背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2955 题目给了每个银行的钱和被抓的概率,由于要抢尽量多的钱,所以要保证尽量不被抓,而抢多个银行之后不被 ...
- win32调试工具原理OutputDebugString以及如何获取输出信息
在应用程序和调试器之间传递数据是通过一个 4KB 大小的共享内存块完成的,并有一个互斥量和两个事件对象用来保护对他的访问.下面就是相关的四个内核对象: 对象名称 对象类型 DBWinMutex Mut ...
