Laravel版本:5.6
API隨著迭代,新版本往往需要繼承老版本的功能,并對(duì)原有的功能修改和擴(kuò)展,這時(shí)為了兼容各個(gè)版本的接口,就需要進(jìn)行版本控制。
請(qǐng)求版本區(qū)分:
在請(qǐng)求的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;
//當(dāng)前版本
$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;
}
注:該方法會(huì)將1.0.2版本解析為v1d0d2,并判斷對(duì)應(yīng)類是否存在,如果存在則直接返回類的路徑;不存在則向下尋找1.0.1版本類是否存在,直到找到存在的類返回。
路由文件
Route::post('login', getRouteContoller('UserController').'login');
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- laravel 配置路由 api和web定義的路由的區(qū)別詳解