我正在尝试制作自己的自定义 Laravel 10 登录/注册,因为我不想使用 breez 包,因为我想了解如何自己进行登录/注册。
但我似乎无法通过仪表板页面的身份验证。
我在仪表板函数上使用 if 语句 if(Auth::check()) 来对数据库中的用户进行身份验证。
但对我来说这不起作用,因为我不断收到从重定向回登录页面的错误消息(这只在我将新用户注册到数据库中时才会发生),但每当我尝试登录 我从登录功能中收到成功消息(进一步查看代码),同时仍在登录页面中。
AuthController(仪表板):
public function dashboard(): View
{
if(Auth::check()) {
return view('auth.dashboard');
}
return view('auth.login')->with('error', 'You are not allowed to access');
}
AuthController(登录):
public function loginPost(Request $request): RedirectResponse
{
$request->validate([
'email' => 'required',
'password' => 'required'
]);
$credentials = $request->only('email', 'password');
if(Auth::attempt($credentials)) {
$request->session()->regenerate();
return redirect()->intended(route('dashboard'))->with('success', 'You have successfully logged in');
}
return redirect(route('login'))->with('error', 'Oppes! You have entered invalid credentials');
}
web.php
Route::get('/register', [AuthController::class, 'register'])->name('register');
Route::post('/register', [AuthController::class, 'registerPost'])->name('register.post');
Route::get('/login', [AuthController::class, 'login'])->name('login');
Route::post('/login', [AuthController::class, 'loginPost'])->name('login.post');
Route::get('/dashboard', [AuthController::class, 'dashboard'])->name('dashboard');
Route::post('/logout', [AuthController::class, 'logout'])->middleware('auth')->name('logout');
我还没有找到任何解决方案,因此如果有人可以帮助我,我将不胜感激。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
hii,您的注销功能受到中间件的保护,您还需要添加仪表板路由中间件,您可以对需要身份验证中间件的路由进行分组。
Route::middleware('auth')->group(function () { Route::get('/dashboard', [AuthController::class, 'dashboard'])->name('dashboard'); Route::post('/logout', [AuthController::class, 'logout'])->name('logout'); });您的路线
Route::get('login', [FrontendAuthController::class, 'loginGet'])->name('login'); Route::post('login', [FrontendAuthController::class, 'loginPost']); Route::post('logout', [FrontendAuthController::class, 'logout'])->name('logout'); Route::get('register', [FrontendAuthController::class, 'registerGet'])->name('register'); Route::post('register', [FrontendAuthController::class, 'registerPost']);您的控制器:
<?php namespace App\Http\Controllers\Frontend; use App\Http\Controllers\Controller; use App\Models\User; use Illuminate\Http\Request; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Hash; use Illuminate\Support\Facades\Session; class FrontendAuthController extends Controller { public function loginGet(Request $request) { return view('front.auth.login'); } public function loginPost(Request $request) { $request->validate([ 'email' => 'required|email', 'password' => 'required', ], [ 'email.required' => 'The email field is required.', 'email.email' => 'Please enter a valid email address.', 'password.required' => 'The password field is required.', ]); $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { return redirect()->intended('/'); } else { return redirect()->back()->withErrors(['email' => 'These credentials do not match our records.']); } } public function logout() { Auth::logout(); Session::flush(); // Clear all session data Session::regenerate(); // Regenerate the session ID return redirect()->route('login'); } public function registerGet() { return view('front.auth.register'); } public function registerPost(Request $request) { $request->validate([ 'name' => 'required|string|max:255', 'email' => 'required|email|unique:users,email', 'password' => 'required|min:8|confirmed', ], [ 'name.required' => 'The name field is required.', 'email.required' => 'The email field is required.', 'email.email' => 'Please enter a valid email address.', 'email.unique' => 'This email address is already registered.', 'password.required' => 'The password field is required.', 'password.min' => 'The password must be at least 8 characters.', 'password.confirmed' => 'The password confirmation does not match.', ]); // Create a new user record $user = new User(); $user->name = $request->input('name'); $user->email = $request->input('email'); $user->password = Hash::make($request->input('password')); $user->save(); // Log in the newly registered user Auth::login($user); // Redirect the user to the home page or any other desired page return redirect()->intended('/'); } }您的登录刀片
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Sign In</title> <link rel="stylesheet" href="{{ url('frontend/css/style.css') }}"> </head> <body> <div class="main"> <section class="signup"> <div class="container"> <div class="signup-content"> <form id="signup-form" class="signup-form" method="POST" action="{{ url('login') }}"> @csrf <!-- <img src="images/logo.svg" alt="">--> <h2 class="form-title">Login Here</h2> <div class="form-group"> <input type="email" class="form-input" value="{{ old('email') }}" name="email" id="email" placeholder="Your Email" /> </div> <div class="form-group"> <input type="text" class="form-input" name="password" id="password" placeholder="Password" /> <span toggle="#password" class="zmdi zmdi-eye field-icon toggle-password"></span> </div> @error('email') <div style="color: red">{{ $message }}</div> @enderror @error('password') <div style="color: red">{{ $message }}</div> @enderror <div class="form-group"> <input type="submit" name="submit" id="submit" class="form-submit" value="Sign in" /> </div> </form> <p class="loginhere"> New User? <a href="reg-form.html" class="loginhere-link">Register here</a> </p> </div> </div> </section> </div> </body> </html>您的注册页面
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Register</title> <link rel="stylesheet" href="{{ url('frontend/css/style.css') }}"> </head> <body> <div class="main"> <section class="signup"> <div class="container"> <div class="signup-content"> <form id="signup-form" class="signup-form" method="POST" action="{{ route('register') }}"> @csrf <h2 class="form-title">Register Here</h2> <div class="form-group"> <input type="text" class="form-input" value="{{ old('name') }}" name="name" id="name" placeholder="Your Name" /> </div> <div class="form-group"> <input type="email" class="form-input" value="{{ old('email') }}" name="email" id="email" placeholder="Your Email" /> </div> <div class="form-group"> <input type="password" class="form-input" name="password" id="password" placeholder="Password" /> <span toggle="#password" class="zmdi zmdi-eye field-icon toggle-password"></span> </div> <div class="form-group"> <input type="password" class="form-input" name="password_confirmation" id="password_confirmation" placeholder="Confirm Password" /> </div> @error('name') <div style="color: red">{{ $message }}</div> @enderror @error('email') <div style="color: red">{{ $message }}</div> @enderror @error('password') <div style="color: red">{{ $message }}</div> @enderror <div class="form-group"> <input type="submit" name="submit" id="submit" class="form-submit" value="Register" /> </div> </form> <p class="loginhere"> Already have an account? <a href="{{ route('login') }}" class="loginhere-link">Login here</a> </p> </div> </div> </section> </div> </body> </html>我想这会解决您的所有疑问