Laravel版本:5.6
API随着迭代,新版本往往需要继承老版本的功能,并对原有的功能修改和扩展,这时为了兼容各个版本的接口,就需要进行版本控制。
请求版本区分:
在请求的header中附带版本信息,如app-version:1.0.1
laravel这边的获取方法:
1
|
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原有的功能,需要继承原有的类
1
2
3
4
5
|
use App\Http\Controllers\Api\UserController as UserCtrl; class UserController extends UserCtrl { ... } |
版本控制
版本解析方法:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
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版本类是否存在,直到找到存在的类返回。
路由文件
1
|
Route::post( 'login' , getRouteContoller( 'UserController' ). 'login' ); |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://segmentfault.com/a/1190000021515729