ホームページ >PHPフレームワーク >Laravel >LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)

LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)

不言
不言オリジナル
2018-08-04 15:00:113677ブラウズ

この記事では、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.phpproviders 数组中注册 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

LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)

7.然后在 AuthServiceProviderboot 方法中添加 Passport::roues();
LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)
8.最后,修改文件 config/auth.phpapi 部分的授权保护项( driver )改为 passport
2. LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)

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');
    });
    });
をインストールします
3. 次に、構成ファイル config/app.phpproviders 配列に 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(&#39;name&#39;));
        if(Auth::attempt([&#39;name&#39; => request(&#39;name&#39;), &#39;password&#39; => request(&#39;password&#39;)])) {            
        $user = Auth::user();            
        $this->content[&#39;token&#39;] =  $user->createToken(request(&#39;name&#39;))->accessToken;            
        $status = 200;
        } else {            
        $this->content[&#39;error&#39;] = "未授权";            
        $status = 401;
        }        
        return response()->json($this->content, $status);
    }    public function passport(){
        return response()->json([&#39;user&#39; => Auth::user()]);
    }    /**
     * 注册用户创建token
     */
    public function register(Request $request){
        $input = $request->all();        
        $validator = Validator::make($input, [
                    &#39;email&#39; => &#39;required|string|email|max:255|unique:users|min:4&#39;,            
                    &#39;password&#39; => &#39;required|string|min:6&#39;,
        ]);        
        if ($validator->fails())
         {            
            return response()->json([&#39;error&#39;=>$validator->errors()], 401);
        }        
        $input[&#39;password&#39;] = bcrypt($input[&#39;password&#39;]);        
        $user = User::create($input);        
        if( $user !==false){            
        $success[&#39;token&#39;] =  $user->createToken($input[&#39;name&#39;])->accessToken;            
        $success[&#39;email&#39;] =  $user->email;            
        $success[&#39;uid&#39;] =  $user->id;            
        return response()->json([&#39;error_code&#39;=>0,&#39;data&#39;=>$success], 200);
        }        
        return response()->json([&#39;error_code&#39;=>1,&#39;data&#39;=>$input], 401);
    }
}

4. パスポートの移行により、アプリケーションがクライアントとアクセストークンを保存するためのデータテーブルが生成されます (移行ファイルの場所/ベンダー/laravel/パスポート/データベース) (関連テーブルを作成します)

rrreee

5.プライベート アクセス クライアントとパスワード アクセス クライアントは、安全なアクセス トークンを生成するために使用されます。

rrreee

注: ここで問題が発生します。つまり、登録後に登録インターフェイスを再度使用すると、phpArtisan Passport:install を再実行するとエラーが報告されます。 OK

6 .TraitAppUser モデルに追加されます。この Trait は、認証されたユーザーのトークンを確認して使用するためのいくつかのヘルパー関数をこのモデルに提供します。
rrreeeLaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)ここに画像の説明を書きます

7. 次に、AuthServiceProviderboot メソッドに Passport::roues(); を追加します。 /code> コード> LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)ここに画像の説明を書きます

8. 最後に、ファイル config/auth.php の <code>api 部分にある認証保護項目を変更します。 code> ( driver ) を passport に変換します。この調整により、アプリケーションは API 認証リクエストの受信時に Passport の TokenGuard を使用して処理できるようになります


LaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)9. テスト ルーティングを追加します

php 職人 make:controller ApiUserController

rrreee

11 を実行します。郵便配達員を通じてトークンを取得する簡単なテスト 登録: インターフェース アドレス: http://gems.com/api/register

ログイン: http://gems.com/api/login

テスト ユーザー情報の取得: http://gems.com/api/v1/passport 🎜🎜🎜🎜 おすすめ関連記事: 🎜🎜🎜laravel フレームワークモデルの作成と使い方 🎜🎜🎜🎜 laravel5.5 フレームワークのビュー間でデータを共有するには?ビュー間でデータを共有する方法 (コードを使用) 🎜🎜🎜🎜

以上がLaravelフレームワークにおけるPossport APIの認証処理の詳細説明(画像とテキスト)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。