この記事では、Laravel フレームワークにおける Possport Api の認証プロセスの詳細な説明 (写真とテキスト) を紹介します。内容は非常に詳細であり、困っている友人に役立つことを願っています。
1. Laravel は従来のログインフォームを通じてユーザー認証を非常に簡単にしましたが、API はどうなるのでしょうか? API は通常、認証にトークンを使用し、リクエスト間のセッション状態を維持しません。 Laravel は Laravel Passport
を使用して API 認証を簡単にします。 Passport は Alex Bilbie が管理する League OAuth2 サーバーに基づいており、Laravel アプリケーションに完全な OAuth2 サーバー実装を数分で提供できます。 Laravel Passport
让API认证变得轻而易举,Passport基于Alex Bilbie维护的League OAuth2 server,可以在数分钟内为Laravel应用提供完整的OAuth2服务器实现。
2.安装
composer require laravel/passport
3.接下来,在配置文件 config/app.php
的providers
数组中注册 Passport
服务提供者:
Laravel\Passport\PassportServiceProvider::class,
4.Passport 迁移将会为应用生成用于存放客户端和访问令牌的数据表 (迁移文件位置/vendor/laravel/passport/database)( 创建相关的表)
php artisan migrate
5.创建生成安全访问令牌时用到的加密密钥及私人访问和密码访问客户端。
php artisan passport:install
注意:到这里会有一个问题,就是当你注册完之后再一次代用注册接口是回报错,在从从新执行一下php artisan passport:install
就OK了
6.Trait
添加到 AppUser
模型中,这个 Trait 会给这个模型提供一些辅助函数,用于检查已认证用户的令牌和使用作用于。
Laravel\Passport\HasApiTokens
7.然后在 AuthServiceProvider
的 boot
方法中添加 Passport::roues();
8.最后,修改文件 config/auth.php
中 api
部分的授权保护项( driver
)改为 passport
2.
Route::group(['namespace'=>'api'], function(){ // 无需认证路由 Route::match(['get','post'],'/login', 'UserController@login')->name('login'); Route::post('/register', 'UserController@register'); // 需认证路由 Route::group(['middleware' => 'auth:api'], function(){ Route::get('/v1/passport', 'UserController@passport'); }); });
config/app.php</code の <code>providers
配列に Passport
サービス プロバイダーを登録します。 > 著者: <?php namespace App\Http\Controllers\Api; use App\User; use Illuminate\Http\Request; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Validator; 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(request('name'))->accessToken; $status = 200; } else { $this->content['error'] = "未授权"; $status = 401; } return response()->json($this->content, $status); } public function passport(){ return response()->json(['user' => Auth::user()]); } /** * 注册用户创建token */ public function register(Request $request){ $input = $request->all(); $validator = Validator::make($input, [ 'email' => 'required|string|email|max:255|unique:users|min:4', 'password' => 'required|string|min:6', ]); if ($validator->fails()) { return response()->json(['error'=>$validator->errors()], 401); } $input['password'] = bcrypt($input['password']); $user = User::create($input); if( $user !==false){ $success['token'] = $user->createToken($input['name'])->accessToken; $success['email'] = $user->email; $success['uid'] = $user->id; return response()->json(['error_code'=>0,'data'=>$success], 200); } return response()->json(['error_code'=>1,'data'=>$input], 401); } }
4. パスポートの移行により、アプリケーションがクライアントとアクセストークンを保存するためのデータテーブルが生成されます (移行ファイルの場所/ベンダー/laravel/パスポート/データベース) (関連テーブルを作成します)
rrreee5.プライベート アクセス クライアントとパスワード アクセス クライアントは、安全なアクセス トークンを生成するために使用されます。
rrreee注: ここで問題が発生します。つまり、登録後に登録インターフェイスを再度使用すると、phpArtisan Passport:install
を再実行するとエラーが報告されます。 OK
6 .Trait
が AppUser
モデルに追加されます。この Trait は、認証されたユーザーのトークンを確認して使用するためのいくつかのヘルパー関数をこのモデルに提供します。
rrreee
7. 次に、AuthServiceProviderboot
メソッドに Passport::roues();
を追加します。 /code> コード>
config/auth.php の <code>api
部分にある認証保護項目を変更します。 code> ( driver
) を passport
に変換します。この調整により、アプリケーションは API 認証リクエストの受信時に Passport の TokenGuard を使用して処理できるようになります
9. テスト ルーティングを追加します
php 職人 make:controller ApiUserController
rrreee11 を実行します。郵便配達員を通じてトークンを取得する簡単なテスト 登録: インターフェース アドレス: http://gems.com/api/register
ログイン: http://gems.com/api/login
テスト ユーザー情報の取得: http://gems.com/api/v1/passport 🎜🎜🎜🎜 おすすめ関連記事: 🎜🎜🎜laravel フレームワークモデルの作成と使い方 🎜🎜🎜🎜 laravel5.5 フレームワークのビュー間でデータを共有するには?ビュー間でデータを共有する方法 (コードを使用) 🎜🎜🎜🎜以上がLaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。