【发布时间】:2019-12-21 10:42:04
【问题描述】:
我使用 Laravel-Passport 对我的 api 端点进行 Laravel 5.8 身份验证
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use App\User;
use Validator;
public function login(Request $request)
{
$validator = Validator::make($request->all('email', 'password'), [
'email' => 'required|string|email|max:255',
'password' => 'required|string|min:6'
]);
if ($validator->fails()) {
return response()->json(['error'=>$validator->errors()], 401);
};
if(Auth::attempt(['email' => request('email'), 'password' => request('password')])){
$user = Auth::user();
$success['token'] = $user->createToken('MyApp')-> accessToken;
return response()->json(['success' => $success], 200);
}
else{
return response()->json(['error'=>'Can not log in with the data provide.'], 401);
}
}
auth.php
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'users',
],
'api' => [
'driver' => 'passport',
'provider' => 'users',
],
],
当我在 POSTMAN 上测试端点时,我得到了这个错误:
错误的原因是什么,我该如何解决?
BadMethodCallException 方法 Illuminate\Auth\RequestGuard::attempt 不存在。
【问题讨论】:
-
当您尝试
Auth::guard('web')->attempt(...时会发生什么? -
当我这样做时,我遇到了另一个错误,如图所示:在 null 上调用成员函数 createToken()
-
您是否也将
Auth::user()更改为Auth::guard('web')->user()? -
非常感谢。它有效
-
很高兴能帮上忙!立即将其发布为答案。
标签: laravel postman laravel-passport