Laravel Auth :: check()总是失败

时间:2020-10-18 04:19:35

标签: php laravel

我正在使用 Laravel 8.9.0 后端api构建ReactJS应用。我正在使用Laravel Auth功能创建令牌并将其传递给我的前端应用程序。我可以使用哈希密码等登录并正确创建令牌。我无法使用下面显示的控制器中的is_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');

1 个答案:

答案 0 :(得分:0)

要解决此问题,您必须在每次请求时将令牌传递到标头中:

在我的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', 'App\Http\Controllers\LoginController@is_login');