Laravel Auth::check()总是失败



我正在用Laravel 8.9.0后端api构建一个ReactJS应用程序。我使用的是Laravel Auth功能,它创建一个令牌并将其传递给我的前端应用程序。我能够登录并使用哈希密码等正确创建令牌;检查登录";在控制器中使用如下所示的CCD_ 1方法。Auth::check()总是失败,我做错了什么?下面是我的控制器和路由api.php文件。请帮忙!

登录控制器:

namespace AppHttpControllers;
use AppHttpControllersController;
use IlluminateHttpRequest;
use IlluminateSupportFacadesAuth;
use AppModelsUsers;
class LoginController extends Controller
{
public function login(Request $request) {
$login = $request->validate([
'email' => 'required:string',
'password' => 'required:string'
]);
if(!Auth::attempt($login)) {
return response([
'message' => 'Invalid Credentials'
]);
}
$accessToken = Auth::user()
->createToken('authToken')
->accessToken;

return response([
'user' => Auth::user(),
'access_token' => $accessToken 
]);
}
public function is_login()
{
$is_login = false;
if (Auth::check()) {
$is_login = true;
}
return response()->json(['is_login' => $is_login]);
}
}

路由api.php

use IlluminateHttpRequest;
use IlluminateSupportFacadesRoute;
Route::post('/login', 'AppHttpControllersLoginController@login');
Route::get('/login-check', 'AppHttpControllersLoginController@is_login');

要解决此问题,必须将令牌与每个请求一起传递到标头中:

在我的ReactJS中,我在componentDidMount()上做到了这一点

componentDidMount() {
try {
const config = {
headers: { 
Authorization: `Bearer ${mytoken}`
}
};


axios.get('/api/login-check',
{ key: "value" },
{ headers: config }
).then(
console.log('succ')
).catch(
console.log('err')
);

} catch (err) {
console.log('Error in submission', err)
}
}

在我的api中,我将中间件添加到检查中:


Route::middleware('auth:api')->get('/login-check', 'AppHttpControllersLoginController@is_login');

相关内容

最新更新