详解Laravel5.6通过路由进行API版本控制的简单方法
程序员文章站
2022-10-15 09:27:50
laravel版本:5.6
api随着迭代,新版本往往需要继承老版本的功能,并对原有的功能修改和扩展,这时为了兼容各个版本的接口,就需要进行版本控制。
请求版本区分:
在...
laravel版本:5.6
api随着迭代,新版本往往需要继承老版本的功能,并对原有的功能修改和扩展,这时为了兼容各个版本的接口,就需要进行版本控制。
请求版本区分:
在请求的header中附带版本信息,如app-version:1.0.1
laravel这边的获取方法:
request::header('app-version');
文件路径:
1.0.1版本的usercontroller,文件路径就是app/http/controllers/api/v1d0d1/usercontroller.php
1.0.2版本,就是app/http/controllers/api/v1d0d2/usercontroller.php
注意1.0.2版本如果需要使用1.0.1原有的功能,需要继承原有的类
use app\http\controllers\api\usercontroller as userctrl; class usercontroller extends userctrl { ... }
版本控制
版本解析方法:
function getroutecontoller($controllername) { $base_path = 'app\http\controllers\api\\'; //无版本 $app_version = request::header('app-version'); if (!$app_version) return $controllername; //当前版本 $version_path = 'v' . str_replace('.', 'd', $app_version) . '\\'; $controllerpath = $base_path . $version_path . $controllername; if (class_exists($controllerpath)) { return $version_path . $controllername; } //往期版本 $versionnumbers = intval(str_replace('.', '', $app_version)); for ($i = $versionnumbers - 1; $i > 0; $i--) { $version_path = 'v' . implode('d', str_split($i)) . '\\'; $controllerpath = $base_path . $version_path . $controllername; if (class_exists($controllerpath)) { return $version_path . $controllername; } } return $controllername; }
注:该方法会将1.0.2版本解析为v1d0d2,并判断对应类是否存在,如果存在则直接返回类的路径;不存在则向下寻找1.0.1版本类是否存在,直到找到存在的类返回。
路由文件
route::post('login', getroutecontoller('usercontroller').'login');
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: .NET微信公众号查看关注者接口