Laravel通過傳統的登錄表單已經讓用戶認證變得很簡單,但是API怎么辦?API通常使用token進行認證并且在請求之間不維護session狀態。Laravel使用Laravel Passport讓API認證變得輕而易舉,Passport基于Alex Bilbie維護的League OAuth2 server,可以在數分鐘內為Laravel應用提供完整的OAuth2服務器實現。
中文文檔
http://laravelacademy.org/post/6813.html
安裝
composer require laravel/passport
接下來,在配置文件 config/app.php 的providers 數組中注冊 Passport 服務提供者:
Laravel\Passport\PassportServiceProvider::class,
Passport 遷移將會為應用生成用于存放客戶端和訪問令牌的數據表 (遷移文件位置/vendor/laravel/passport/database)
php artisan migrate
創建生成安全訪問令牌時用到的加密密鑰及私人訪問和密碼訪問客戶端。
php artisan passport:install
Trait 添加到 App\User 模型中,這個 Trait 會給這個模型提供一些輔助函數,用于檢查已認證用戶的令牌和使用作用于。
Laravel\Passport\HasApiTokens
然后在 AuthServiceProvider 的 boot 方法中添加 Passport::roues();
最后,修改文件 config/auth.php 中 api 部分的授權保護項( driver )改為 passport 。此調整會讓你的應用程序在接收到 API 的授權請求時使用 Passport 的 TokenGuard 來處理
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ], 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ],
增加測試路由
Route::group(['namespace' => 'api'], function () { Route::post('/login', 'UserController@login'); }); Route::group(['middleware' => 'auth:api', 'namespace' => 'api'], function() { Route::get('V1/test/passport', 'UserController@passport'); });
增加控制器
php artisen make:controller UserController
?php namespace App\Http\Controllers\Api; use Illuminate\Http\Request; use App\Http\Controllers\Controller; use Auth; class UserController extends Controller { public function __construct() { $this->content = array(); } public function login() { // dd(request('name')); if(Auth::attempt(['name' => request('name'), 'password' => request('password')])) { $user = Auth::user(); $this->content['token'] = $user->createToken('Pi App')->accessToken; $status = 200; } else { $this->content['error'] = "未授權"; $status = 401; } return response()->json($this->content, $status); } public function passport() { return response()->json(['user' => Auth::user()]); } }
通過postman進行簡單測試獲取token
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。