首页 > 解决方案 > Laravel 7 使用 Passport 进行多重身份验证

问题描述

我正在开发需要为多个用户生成访问令牌的 Laravel 应用程序。我正在使用带有密码授予的 Laravel Passport 来颁发令牌。我遵循了 Laravel 文档,但是当我尝试使用 Postman 调用我的 API 端点(学生)时,我被重定向到登录路由,似乎我做错了。后来我发现重定向来自我创建的中间件,但我仍然不知道出了什么问题

授权文件

        'guards' => [
                'web' => [
                    'driver' => 'session',
                    'provider' => 'users',
                ],
        
                'api' => [
                    'driver' => 'passport',
                    'provider' => 'users',
                    'hash' => false,
                ],
               
                'api-student' => [
                    'driver' => 'passport',
                    'provider' => 'students',
                    'hash' => false,
                ]
    ];
    
    
         'providers' => [
                'users' => [
                    'driver' => 'eloquent',
                    'model' => App\User::class,
                ],
                'students' => [
                    'driver' => 'eloquent',
                    'model' => App\Student::class,
                ],
                 
            ],

api.php

    Route::post('auth/getlogin', 'Api\StudentController@authenticate')->middleware('auth:api-student');
    
    //Api\StudentController
    public function authenticate(Request $request, Student $user)
        {
            $credentials = [
                'username'=>$request->username,
                'password'=>$request->password];
          
            if(!Auth::guard('api-student')->attempt($credentials)) {
                return response()->json([
                    'message'=>'Error'
                ], 401);
            }
             
            if(Auth::guard('api-student')->attempt($credentials)){
                $user = Auth::guard('client');
                $success['token'] =  $user->createToken('MyApp')->accessToken;
                return response()->json(['success' => $success], $this->successStatus);
            }
            else{
                return response()->json(['error'=>'Username or password incorrect'], 401);
            }
        }

标签: phplaraveloauth-2.0laravel-passport

解决方案


删除middleware以便任何人都可以登录

Route::post('auth/getlogin', 'Api\StudentController@authenticate')->middleware('auth:api-student');
    

Route::post('auth/getlogin', 'Api\StudentController@authenticate'); 

middleware在这里申请所以在做任何行动之前它检查路线auth是否


推荐阅读