这篇文章主要介绍了Laravel5.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');
感谢你能够认真阅读完这篇文章,希望小编分享的“Laravel5.6如何通过路由进行API版本控制”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。