Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/variables/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php Laravel Auth::check()总是失败_Php_Laravel - Fatal编程技术网

Php Laravel Auth::check()总是失败

Php Laravel Auth::check()总是失败,php,laravel,Php,Laravel,我正在构建一个带有Laravel 8.9.0后端api的ReactJS应用程序。我正在使用Laravel Auth功能创建令牌并将其传递给我的前端应用程序。我能够登录并使用哈希密码等正确创建令牌。我无法使用控制器中下面显示的is\u Login方法“检查登录”。Auth::check()总是失败,我做错了什么?下面是我的控制器和路由api.php文件。请帮忙 登录控制器: namespace App\Http\Controllers; use App\Http\Controllers\Cont

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

登录控制器:

namespace App\Http\Controllers;

use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use App\Models\Users;

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 Illuminate\Http\Request;
use Illuminate\Support\Facades\Route;

Route::post('/login', 'App\Http\Controllers\LoginController@login');
Route::get('/login-check', 'App\Http\Controllers\LoginController@is_login');

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

在我的ReactJS中,我是在
componentDidMount()上做的

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


Route::middleware('auth:api')->get('/login-check', 'App\Http\Controllers\LoginController@is_login');

Auth::guard('api')->check()有效吗?你在头中传递令牌吗?@nakov它也返回false,我没有在头中传递令牌否,但我认为后端应该自动工作。那么,后端如何知道它是发出请求的有效用户?它是哪个用户?这就是为什么要在一天结束时创建令牌。如果你使用会话驱动程序,后端知道它是哪个用户。是的,你是对的,我在下面分享我的答案

Route::middleware('auth:api')->get('/login-check', 'App\Http\Controllers\LoginController@is_login');