Laravel 7使用Passport的多重身份验证

时间:2020-09-12 06:33:44

标签: php laravel oauth-2.0 laravel-passport

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

auth.php

        '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);
            }
        }

1 个答案:

答案 0 :(得分:0)

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

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

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

您在此处应用了middleware,因此在执行任何操作之前,它会检查是否auth路由