3 Star 0 Fork 1

Gitee 极速下载 / NHVersion

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
此仓库是为了提升国内下载速度的镜像仓库,每日同步一次。 原始仓库: https://github.com/jeffreyning/NHVersion
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

NHVersion

NHVersion类库

api接口需要分版本同时提出给使用方,通常移动端app的后台接口有这种版本化需求。如果每个接口都重新改类名将造成大量重复代码。 使用NHVersion类库可以解决代码重复问题,同时在没有完全一致的版本映射时,还可以根据提供的版本号找到最近似的版本进行调用。 NHVersion类库的开源代码请访问https://github.com/jeffreyning/NHVersion 下载jar请访问nhversion-1.0.jar 下载jar(支持spring)请访问nhversion-1.1.jar

nhversion-1.3.0-RELEASE.jar已经加入maven.org中央仓库

nhversion-1.3.0添加了前端version与后端version映射的功能 比如移动端app与后台接口的version是两个团队分别维护,需要进行映射配置

在没有NHVersion类库的情况下,一般会用ifelse处理多版本判断,例如以下的代码 名为Calcu的接口通过ifelse判断v1_0_1 v_1_0_5 v1_1_0这3个版本如果需要增加新的版本, 则需要修改Calcu类内部ifelse逻辑,这样容易出错,而且每个版本都要重新编写。 public class NoNHVersionController { public static int calcu(int param,String version){ if(version.equals("v1_0_1")){ System.out.println("this is nonhversioin v1_0_1"); return param+1; }else if(version.equals("v1_0_5")){ System.out.println("this is nonhversion v1_0_5"); return param+5; }else if(version.equals("v1_1_0")){ System.out.println("this is nonhversion v1_1_0"); return param+10; } System.out.println("this is nonhversion not catch"); return 0; } }

NHVersion类库将处理逻辑抽象成handler,通过map维护handler与version的映射关系。 增加新版本时只需实现新的handler对象并注入map中,不必修改接口主类的代码。而且可以支持版本号自动降级匹配。 比如V1_0_6没有完全相等handler,则会自动降级匹配V1_0_5进行调用。

每个不同版本需要编写handler @ControllerMappingAnno(controllerName="NHVersionController",funcName="calcu",funcVer="v1_0_0") 注解的作用是配置handler与version的映射关系。如NHVersionController接口类,calcu方法对应,v1_0_0版本的handler对象CalcuCmd1 支持按照springbeanid加载cmd对象@ControllerMappingAnno(controllerName="NHVersionController",funcName="calcu",funcVer="v1_0_0" beanId="cmd1")

package com.jeffreyning.nhversion.demo.controller.cmd; import java.util.HashMap; import java.util.Map;

import com.jeffreyning.nhversion.common.version.cmd.IControllerCommand; import com.jeffreyning.nhversion.common.version.mapping.ControllerMappingAnno; //@Component("cmd1") //@ControllerMappingAnno(controllerName="NHVersionController",funcName="calcu",funcVer="v1_0_0" beanId="cmd1") @ControllerMappingAnno(controllerName="NHVersionController",funcName="calcu",funcVer="v1_0_0") public class CalcuCmd1 extends IControllerCommand{

@Override
public Map execute(Map paramMap) {
	System.out.println("this is nhversion v1_0_0");
	int param=(Integer) paramMap.get("param");
	int ret=param+1;
	Map retMap=new HashMap();
	retMap.put("retInt", ret);
	return retMap;
}

}

使用NHVersion类库后接口层改写为 CommonControllerMapping.execVersionMapping触发版本映射并调用找出的handler对象。 参数为接口类标识、方法标识,版本号,参数(map) public class NHVersionController { public static int calcu(int param,String version){ Map paramMap=new HashMap(); paramMap.put("version", version); paramMap.put("param", param); Map retMap=CommonControllerMapping.execVersionMapping("NHVersionController","calcu", version, paramMap); Integer retInt=(Integer) retMap.get("retInt"); return retInt; } }

@ControllerMappingAnno维护的映射关系,通过自动扫描注入到map中 CommonControllerMapping.batchRegistryByPackage("com.jeffreyning.nhversion.demo.controller.cmd"); package com.jeffreyning.nhversion.demo;

import com.jeffreyning.nhversion.common.version.mapping.CommonControllerMapping; import com.jeffreyning.nhversion.demo.controller.NoNHVersionController; import com.jeffreyning.nhversion.demo.controller.NHVersionController;

public class Demo {

public static void main(String[] args) throws Exception {
	CommonControllerMapping.batchRegistryByPackage("com.jeffreyning.nhversion.demo.controller.cmd");
	NoNHVersionController.calcu(1, "v1_0_1");
	NHVersionController.calcu(1,"v1_0_1");
	NoNHVersionController.calcu(1, "v1_0_6");
	NHVersionController.calcu(1,"v1_0_6");
}

}

比如移动端app与后台接口的version是两个团队分别维护,需要进行映射配置 例如移动端v3_1_0明确配置映射为后台v1_0_5 例如移动端v3_1_1没有明确配置映射,则自动降级为后台v1_0_5 例如移动端v3_2_0明确配置映射为后台v1_1_0 注意前台version是按照字符串排序自动降级的 在controller收到前端version字符串时使用VersionMappingUtil.mappingVer获取后端version字符串 再进行CommonControllerMapping.execVersionMapping调用 public class FrontVersionChangeController { public static int calcu(int param,String frontVer){ String version=VersionMappingUtil.mappingVer(frontVer); System.out.println("frontVer is "+frontVer+" change to backVer is "+version); Map paramMap=new HashMap(); paramMap.put("version", version); paramMap.put("param", param); Map retMap=CommonControllerMapping.execVersionMapping("NHVersionController","calcu", version, paramMap); Integer retInt=(Integer) retMap.get("retInt"); return retInt; } }

注意:版本号格式为vxx_xx_xx xx代表2位数字 如v01_0_10 v1_1_6都是正确的格式 如果需要加载spring中的cmd对象,需要配置在spring配置文件中添加   

空文件

简介

版本 API 接口管理工具 展开 收起
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
Java
1
https://gitee.com/mirrors/NHVersion.git
git@gitee.com:mirrors/NHVersion.git
mirrors
NHVersion
NHVersion
master

搜索帮助