Laravel/Lumen 優化包 - 註解注入路由自動配置

背景

  1. 因大量的路由配置信息,不一樣時段的多人員開發,形成git衝突
  2. 路由信息過多,形成維護困難

安裝

composer require qklin/laravel-auto-router

註冊中間件和提供者

安裝包裏已包含了幾個demo版本的Middleware,自取自用php

# add autorouter middleware
$app->routeMiddleware([
    //...

    'check_sign'   => \Qikl\AutoRouter\Middleware\CheckSignMiddleware::class,
    // ... more
]);

# add provider
$app->register(Qklin\AutoRouter\AppServiceProvider::class);

env

AUTO_ROUTER_MODULE_DIR=Modules
LARAVEL_ORIGIN_HTTP_PREFIX=h
AUTOROUTER_MODULE_HTTP_PREFIX=m,inside
AUTOROUTER_DEFAULT_MIDDLEWARE=token
AUTOROUTER_PROVIDER_START=1
AUTOROUTER_MIDDLEWARE_SUFFIX=OLNVIX

# middleware
AR_INSIDE_HOSTS=www.baidu.com,www.google.com
AR_CHECK_SIGN_TIMEOUT=30
AR_CHECK_SIGN_KEY=sdfsdfdf
AR_AUTH_API_DOMAIN=http://auth.baidu.com/checkauth
AR_API_THROTTLE=ar_api_throttle

# document variable
AR_DOCUMENT_ROUTER=arRouter
AR_DOCUMENT_METHOD=arMethod
AR_DOCUMENT_ONLY_INSIDE=arOnlyInside

使用

兼容原有已有在route.php裏配置的路由laravel

目前支持的註解

默認取上面定義名稱來講明git

  1. arRouter: 可直接配置方法攜帶後綴控制中間件
  2. arMethod: POST|GET|PUT|...
  3. arOnlyInisde: 路由必須inside開頭

路由自動注入使用

  1. api必須env配置(AUTOROUTER_MODULE_HTTP_PREFIX)前綴。
  2. 路徑包含駝峯目錄以【_】分隔。like:HotKeys => hot_keys
  3. 方法包含【.】的目錄以【_】分隔。like:V1.0 => v1_0
  4. 方法包含駝峯以【-】分隔。like:getListsO => get-list-o

控制器方法添加註解配置案例

具體案例, 模塊根目錄和控制器文件:app/Modules/Module/Hotkeys/V1.0/Controllers/IndexController.php
方法:getList,註解arRouter getListO
路由:/m/module/hot-keys/v1_0/index/get-list-o

/**
 * 案例一 純路由註解
 * 匹配:/m/module/articles/college/detail
 * @arRouter
 * @return string
 */
public function detail()
{
}
 
/**
 * 案例二:路由註解並配置路由地址方法
 * 匹配:/m/module/articles/college/detail-o
 * @arRouter detailO
 * @return string
 */
public function detail()
{
}
 
 
/**
 * 案例三:路由註解請求方法和開啓內網註解
 * 匹配,且前綴必須inside開頭:/inside/module/articles/college/detail-o
 * 只支持post和get請求方法
 * @arRouter detailO
 * @arMehtod POST|GET
 * @arOnlyInside
 * @return string
 */
public function detail()
{
}

註解配置說明

  1. O:Operate 操做 自動注入節流中間件
  2. L:Look 查看 自動移除節流中間件[若是存在]
  3. I:Inside 內網 自動注入內網中間件,且放置最前[若是不存在],自動剔除token中間件
  4. N:NotAuth 無需受權,公開api,自動移除token中間件[若是存在]
  5. V:validate 請求驗證,自動移除請求驗證中間件[若是不存在]
  6. X:checkSign 請求驗籤
  7. 若是都不存在,默認根據route.php配置走

配置route.conf

// 文件位置:app/config/route.php
// 本文件可配置可不配置,根據需求配置
return [
    "middleware" => [  //中間件,目前只支持
        "controllers" => [ // 路由控制器路徑 => 中間件
            "m/module/ctl/action" => ["token", "validate"],
        ],
        "actions"     => [ // 控制器方法 => 中間件
        ]
    ]
];

laravel版本

需在Application能夠注入configure方法api

/**
 * 加載配置文件
 * @param $name
 */
public function configure($name)
{
    if (isset($this->loadedConfigurations[$name])) {
        return;
    }

    $this->loadedConfigurations[$name] = true;

    $path = $this->getConfigurationPath($name);

    if ($path && is_file($path)) {
        $this->make('config')->set($name, require $path);
    }
}

/**
 * 獲取配置路徑
 * @param null $name
 * @return string
 */
public function getConfigurationPath($name = null)
{
    if (!$name) {
        $appConfigDir = $this->basePath('config') . '/';

        if (file_exists($appConfigDir)) {
            return $appConfigDir;
        } else if (file_exists($path = __DIR__ . '/../config/')) {
            return $path;
        }
    } else {
        $appConfigPath = $this->basePath('config') . '/' . $name . '.php';

        if (file_exists($appConfigPath)) {
            return $appConfigPath;
        } else if (file_exists($path = __DIR__ . '/../config/' . $name . '.php')) {
            return $path;
        }
    }
}
相關文章
相關標籤/搜索