auth:api 在 Laravel 的 Routing , Middleware , API Authentication 主題中都有出現。php
一.html
在 Routing 部分能夠知道 auth:api 是中間件的名字,表明某個中間件實現,使用方式爲 Route::middleware('auth:api')。laravel
二.api
在 Middleware 部分能夠知道 auth:api 冒號後面的是 中間件參數,多個參數就用逗號分隔,也就是說 'api' 是 auth 中間件的參數。auth 中間件在 app/Http/Kernel.php 的路由中間件裏定義:protected $routeMiddleware = [ 'auth' => \App\Http\Middleware\Authenticate::class ]。app
Middleware 中間件都是在 handle 方法裏對請求進行驗證的,handle 前面兩個參數是 $request, Closure $next。中間件參數在 handle 的默認參數後面,例如 user:creater,editer 就表示 user 中間件的 handle 方法的第三個參數值是 creater, 第四個參數值是 editer。ide
對於 Auth 中間件來講,參數值 api 表示所使用的 guard 是 api,咱們能夠看其所繼承的父類實現:this
// Illuminate\Auth\Middleware\Authenticate->handle() public function handle($request, Closure $next, ...$guards) { $this->authenticate($request, $guards); return $next($request); }
裏面的驗證所使用的就是下面要講的 Auth 功能類(AuthManager)。spa
三.code
在 API Authentication 部分,config/auth.php 配置有多個 guards,分別有本身的 driver 和 providers。htm
另外 Auth Facade (AuthManager) 提供了 Auth::guard() 方法用於決定 Auth 所使用的 guard。
Auth(Facade)提供了統一的方法來處理用戶認證檢測、驅動的擴展,經過更改配置而不是代碼來使用不一樣的驅動。
Auth 內置了兩種驅動的實現,AuthManager->createSessionDriver($name, $config), AuthManager->createTokenDriver($name, $config)。
若是你想更進一步瞭解 API Authentication 的運行過程,建議閱讀一下 createTokenDriver() 內部實例化的 TokenGuard 類。
TokenGuard 會順序檢測 "query request"、"input request"、"header 鍵爲 Authentication 值爲 bearer xxx",從中獲取 token 值;接着根據配置中的 provider 的值建立 provider 具體實例來驗證 token。
有關 auth:api 與 Auth 的意義大體如此。