使用 Passport 掌握 Laravel 驗證:逐步指南
身份驗證是現代 Web 應用程式的基石。在 Laravel 中,Passport 提供了完整的 OAuth2 伺服器實現,可以無縫地實現 API 驗證。本指南將引導您完成設定 Laravel Passport 的整個流程,從安裝到保護和測試 API。
簡介
為什麼要使用 Laravel Passport?
Laravel Passport 透過與 Laravel 生態系統緊密整合來簡化 OAuth2 身分驗證的複雜性。有了護照,您可以:
- 安全地驗證 API 使用者身分。
- 為行動和網路用戶端產生個人存取權杖。
- 輕鬆管理令牌過期和撤銷。
先決條件
開始之前,請確保您擁有:
- 對 Laravel 的基本了解。
- 安裝並設定資料庫的 Laravel 專案(建議 v10.x 或更高版本)。
- 已安裝 PHP 8.0 或更高版本。
如果您尚未設定項目,請使用以下內容建立項目:
composer create-project --prefer-dist laravel/laravel passport-auth cd passport-auth
第 1 步:安裝 Laravel Passport
安裝包
執行以下命令將 Passport 新增至您的專案:
composer require laravel/passport
發布和遷移護照文件
發布 Passport 遷移和設定檔:
php artisan vendor:publish --tag=passport-migrations php artisan migrate
第 2 步:配置 Laravel Passport
安裝加密金鑰和用戶端
執行安裝指令:
php artisan passport:install
這會產生加密金鑰並在您的資料庫中建立 OAuth 用戶端。記下輸出,尤其是客戶端 ID 和機密。
可選:建立個人存取用戶端
要明確建立個人存取用戶端,請執行:
php artisan passport:client --personal
第 3 步:更新模型
將 HasApiTokens 特徵加入您的使用者模型:
use Laravel\Passport\HasApiTokens; class User extends Authenticatable { use HasApiTokens, Notifiable; // Other properties... }
第 4 步:更新驗證設定
在 config/auth.php 中將 Passport 配置為 API Guard 的驅動程式:
'guards' => [ 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ],
第5步:註冊護照路線
在AppProvidersAppServiceProvider中,載入Passport的路由:
use Laravel\Passport\Passport; public function boot(): void { Passport::routes(); Passport::tokensExpireIn(now()->addDays(15)); Passport::refreshTokensExpireIn(now()->addDays(30)); Passport::personalAccessTokensExpireIn(now()->addMonths(6)); }
第 6 步:建立驗證 API 端點
新增路線
在routes/api.php中定義API路由:
use App\Http\Controllers\AuthController; Route::post('/register', [AuthController::class, 'register']); Route::post('/login', [AuthController::class, 'login']); Route::middleware('auth:api')->get('/user', [AuthController::class, 'user']);
建立身份驗證控制器
實作驗證方法:
composer create-project --prefer-dist laravel/laravel passport-auth cd passport-auth
第 7 步:設定加密金鑰的權限
確保安全存取護照金鑰:
composer require laravel/passport
驗證權限:
php artisan vendor:publish --tag=passport-migrations php artisan migrate
預期輸出:
php artisan passport:install
第 8 步:測試 API
使用 Postman 或任何 API 用戶端來測試端點:
- 註冊: 使用姓名、電子郵件和密碼向 /register 發送 POST 請求。
- 登入:使用電子郵件和密碼向 /login 發送 POST 請求。
- 取得使用者資料:使用授權標頭中的令牌向 /user 發送 GET 請求。
最佳實踐
- 在生產中使用 HTTPS。
- 定期輪換加密金鑰。
- 徹底驗證輸入。
- 限制令牌範圍以提高安全性。
結論
恭喜!您已經使用 Laravel Passport 成功實作了 API 驗證。此設定為保護 API 提供了堅實的基礎。探索進階 Passport 功能,例如範圍、令牌撤銷和用戶端憑證,以進一步增強應用程式的安全性。
以上是使用 Passport 進行 Laravel 身份驗證的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

PHP日誌記錄對於監視和調試Web應用程序以及捕獲關鍵事件,錯誤和運行時行為至關重要。它為系統性能提供了寶貴的見解,有助於識別問題並支持更快的故障排除

Laravel的服務容器和服務提供商是其架構的基礎。 本文探討了服務容器,詳細信息服務提供商創建,註冊,並通過示例演示了實際用法。 我們將從OVE開始


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3漢化版
中文版,非常好用

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。