当前位置:首页 > CMS教程 > 其它CMS > 列表

详解Laravel5.6通过路由进行API版本控制的简单方法

发布:smiling 来源: PHP粉丝网  添加日期:2022-02-03 20:24:37 浏览: 评论:0 

这篇文章主要介绍了详解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原有的功能,需要继承原有的类

  1. use App\Http\Controllers\Api\UserController as UserCtrl; 
  2. class UserController extends UserCtrl 
  3.   ... 

版本控制

版本解析方法:

  1. function getRouteContoller($controllerName
  2.   $base_path = 'App\Http\Controllers\Api\\'
  3.   //无版本 
  4.   $app_version = Request::header('app-version'); 
  5.   if (!$app_versionreturn $controllerName
  6.   //当前版本 
  7.   $version_path = 'v' . str_replace('.''d'$app_version) . '\\'
  8.   $controllerPath = $base_path . $version_path . $controllerName
  9.   if (class_exists($controllerPath)) { 
  10.     return $version_path . $controllerName
  11.   } 
  12.   //往期版本 
  13.   $versionNumbers = intval(str_replace('.'''$app_version)); 
  14.   for ($i = $versionNumbers - 1; $i > 0; $i--) { 
  15.     $version_path = 'v' . implode('d'str_split($i)) . '\\'
  16.     $controllerPath = $base_path . $version_path . $controllerName
  17.     if (class_exists($controllerPath)) { 
  18.       return $version_path . $controllerName
  19.     } 
  20.   } 
  21.   return $controllerName

注:该方法会将1.0.2版本解析为v1d0d2,并判断对应类是否存在,如果存在则直接返回类的路径;不存在则向下寻找1.0.1版本类是否存在,直到找到存在的类返回。

路由文件

Route::post('login', getRouteContoller('UserController').'login');

Tags: Laravel5.6 API版本控制

分享到: