我正在使用 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');
答案 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');