API シナリオで承認要件を満たすにはどうすればよいですか?
はじめに
Laravel では、従来のフォームに基づいてログインと承認を実装するのは非常に簡単ですが、API シナリオで承認要件を満たすにはどうすればよいでしょうか? API シナリオでは、通常、ユーザー認証はリクエスト間のセッション状態を維持するのではなく、トークンを通じて実装されます。 Passport を使用して、Laravel プロジェクトに API 認証プロセスを簡単に実装できるようになりました。Passport を使用すると、完全な OAuth2 サーバー実装を数分でアプリケーションに追加できます。
インストール
Composer 依存関係パッケージ マネージャーを使用して Passport をインストールします:
composer require laravel/passport
次に、構成ファイル config/app.php:
Laravel\Passport\PassportServiceProvider::class
のプロバイダー配列に Passport サービス プロバイダーを登録します。サービス プロバイダーは内部データベース移行スクリプト ディレクトリを登録するため、前の手順が完了した後、データベース構造を更新する必要があります。パスポートの移行スクリプトは、アプリケーションに必要なクライアント データ テーブルとトークン データ テーブルを自動的に作成します:
php artisan migrate
次に、passport:install コマンドを実行して、セキュア アクセス トークンの生成に使用される暗号化キーを作成する必要があります。このコマンドは、「プライベート アクセス」クライアントと「パスワード認証」クライアントも作成します:
php artisan passport:install
上記のコマンドを実行した後、AppUser.php を変更して、認証されたユーザー ドメインのトークンと使用状況を確認します:
<?php namespace App;use Laravel\Passport\HasApiTokens; // 新增use Illuminate\Notifications\Notifiable;use Illuminate\Foundation\Auth\User as Authenticatable;class User extends Authenticatable {use HasApiTokens, Notifiable; // 增加 HasApiTokens
次に、AuthServiceProvider のブート メソッドで Passport::routes 関数を呼び出す必要があります。この関数は、アクセス トークン、クライアント、およびプライベート アクセス トークンの発行および失効プロセスで使用されるいくつかの必要なルートを登録します。
AppProvidersAuthServiceProvider.php を変更します:
<?php namespace App\Providers;use Laravel\Passport\Passport; // 新增use Illuminate\Support\Facades\Gate;use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;use Carbon\Carbon; // 新增引用class AuthServiceProvider extends ServiceProvider {/** * The policy mappings for the application. * * @var array */protected $policies = ['App\Model' => 'App\Policies\ModelPolicy',];/** * Register any authentication / authorization services. * * @return void */public function boot() {$this->registerPolicies(); Passport::routes(); // 注册passport路由 //令牌的有效期Passport::tokensExpireIn(Carbon::now()->addDays(15)); Passport::refreshTokensExpireIn(Carbon::now()->addDays(30)); } }
最後に、構成ファイル config を変更する必要があります。 / auth.phpのAPI部分の認可保護項目(ドライバー)をパスポートに変更します。この調整により、アプリケーションは API から認可リクエストを受信したときに Passport の TokenGuard を使用するようになります:
'guards' => ['web' => ['driver' => 'session', 'provider' => 'users',], 'api' => ['driver' => 'passport', // 改为passport'provider' => 'users',],],
Test
api のルートは api.php です。 Routeapi.php を開き、テスト ルートを追加します。
Route::group(['namespace' => 'api'], function () { Route::post('/login', 'UserController@login'); }); Route::group(['middleware' => 'auth:api', 'namespace' => 'api'], function() { Route::get('details', 'UserController@details'); });
1 つはログインしてトークンを取得するために使用され、もう 1 つは取得したトークンでログイン認証を完了し、現在のユーザー情報を取得するために使用されます。
詳細ルーティングは、auth:api ミドルウェアを使用してトークンを検証します。
AppHttp ディレクトリに API フォルダーを作成し、UserController.php を追加します
<?php namespace App\Http\Controllers\api;use Illuminate\Http\Request;use App\Http\Controllers\Controller;use Illuminate\Support\Facades\Auth;use App\User;use Response;class UserController extends Controller {public function __construct() {$this->content = array(); }public function login() {if(Auth::attempt(['email' => request('email'), 'password' => request('password')])) {$user = Auth::user();$this->content['token'] = $user->createToken('Pizza App')->accessToken;$status = 200; } else {$this->content['error'] = "未授权"; $status = 401; } return response()->json($this->content, $status); }public function details() {return response()->json(['user' => Auth::user()]); } }
postman でテストします:
上の図に示すように、ログイン メソッドはルートと一致し、post メソッドを使用し、送信する必要がありますユーザーをフォームに入力し、メールアドレスとパスワードを api/login に渡します
正しく渡された場合、上の図のトークンを取得します
前のステップで取得したトークンをヘッダーに追加しますそれをトークン「Bearer」の前に追加します。その後、現在のユーザーの情報を取得できます。つまり、ユーザ認証が完了する。
上記は完全に正しいという保証はありません。私の GitHub コードをご覧いただきありがとうございます。
以上がAPI シナリオで承認要件を満たすにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









最近、ファーウェイは、Xuanjiセンシングシステムを搭載した新しいスマートウェアラブル製品を9月に発売すると発表しました。これはファーウェイの最新スマートウォッチとなる予定です。この新製品は、高度な感情的健康モニタリング機能を統合し、正確性、包括性、スピード、柔軟性、オープン性、拡張性という 6 つの特徴を備えた包括的な健康評価をユーザーに提供します。このシステムはスーパーセンシングモジュールを使用し、マルチチャンネル光路アーキテクチャ技術を最適化することで、心拍数、血中酸素、呼吸数などの基本的な指標の監視精度を大幅に向上させます。さらに、Xuanji センシング システムは、心拍数データに基づく感情状態の研究も拡張しており、生理学的指標に限定されず、ユーザーの感情状態やストレス レベルを評価することもでき、60 以上のスポーツのモニタリングをサポートしています。健康指標、心臓血管、呼吸器、神経、内分泌、

Laravel - アーティザン コマンド - Laravel 5.7 には、新しいコマンドを処理およびテストするための新しい方法が付属しています。これには職人コマンドをテストする新しい機能が含まれており、そのデモについては以下で説明します。

Laravel - ページネーションのカスタマイズ - Laravel には、ユーザーまたは開発者がページネーション機能を組み込むのに役立つページネーションの機能が含まれています。 Laravel ページネーターは、クエリ ビルダーおよび Eloquent ORM と統合されています。自動ページネーションメソッド

Laravelの電子メールの送信が失敗したときに戻りコードを取得する方法。 Laravelを使用してアプリケーションを開発する場合、検証コードを送信する必要がある状況に遭遇することがよくあります。そして実際には...

LaravelスケジュールタスクRAN RANSPONSIVEトラブルシューティングRALAVELのスケジュールタスクスケジューリングを使用すると、多くの開発者がこの問題に遭遇します。スケジュール:実行...

Laravelの電子メールの検証コードの送信の障害を処理する方法は、Laravelを使用することです...

DCATを使用するときにDCATADMIN(Laravel-Admin)にデータを追加するためにカスタムクリックのテーブル関数を実装する方法...

Laravel - ダンプサーバー - Laravel ダンプサーバーには、Laravel 5.7 のバージョンが付属しています。以前のバージョンにはダンプ サーバーが含まれていません。ダンプサーバーはlaravel/laravelコンポーザーファイルの開発依存関係になります。
