公共函数存储(Request $request) { $请求->验证([ '电子邮件' => '必填|电子邮件', '密码' => '必需的', ]); $credentials = $request->only('电子邮件', '密码'); if (auth()->尝试($credentials)) { $user = auth()->user(); $request->session()->put('user', $user); 返回重定向()->路由('home'); } 抛出 ValidationException::withMessages([ '电子邮件' => '无效的电子邮件或密码。', ]); }</pre> <p>这是HTML代码:</p>; <头> <元字符集=“UTF-8”> <标题>登录标题> </头> <正文>登录
<表单动作=“/登录”方法=“发布”> @csrf <输入类型=“电子邮件”姓名=“电子邮件” placeholder="电子邮件"> <输入类型=“密码”名称=“密码” placeholder=“密码”> <输入类型=“提交” value=“登录”> </表格> </正文> </html></pre> <p>最后,是路由:</p>name('users.index'); 路线::get('/users/create', [UserController::class, 'create']); 路线::post('/users', [UserController::class, 'store']); 路线::get('/users/{user}', [UserController::class, 'show']); 路线::get('/users/{user}/edit', [UserController::class, 'edit']); 路线::put('/users/{user}', [UserController::class, 'update']); Route::delete('/users/{user}', [UserController::class, 'destroy'])->name('users.destroy'); 路线::get('/home', [HomeController::class, 'index'])->name('home'); 路线::get('/login', [LoginController::class, 'index'])->name('login'); 路线::post('/login', [LoginController::class, 'store']); ?></pre> <p>我尝试使用登录表单中提供的凭据对用户进行身份验证。如果凭据正确,我希望 Laravel 能够正确地对用户进行身份验证。我还在<code>LoginController</code>的<code>store()</code>方法中使用<code>$request->validate([...])</code>设置了验证规则。我期望如果电子邮件和密码字段没有正确填写,Laravel会在<code>login.blade.php</code>视图上显示错误消息。</p> <p>当我使用正确的凭据提交登录表单时,Laravel无法正确地对用户进行身份验证,并且在不显示任何错误消息的情况下重定向回登录页面。当我使用空字段或无效数据提交表单时,相应的错误消息也不会显示在视图上。相反,表单会在没有任何反馈的情况下重定向回登录页面。</p> <p>我相信由于某些内容缺失或配置不正确,Laravel无法正确地对用户进行身份验证并显示验证消息。</p> <p>如果您能提供任何帮助来解决这个问题,我将非常感激。</p>
P粉5026087992023-09-05 00:46:08
您最初验证了电子邮件和密码,这是很好的。登录失败后,您抛出了一个异常,这就是为什么它不会将您重定向到登录页面的原因。所以应该重定向到带有错误的上一页。
因此,将store方法修改如下:
public function store(Request $request) { $request->validate([ 'email' => 'required|email', 'password' => 'required', ]); $credentials = $request->only('email', 'password'); if (auth()->attempt($credentials)) { $user = auth()->user(); $request->session()->put('user', $user); return redirect()->route('home'); } return redirect()->back()->withErrors(['msg' => '使用的电子邮件或密码无效。']); }
现在,在登录页面的blade文件中使用以下代码,这将打印错误。根据需要修改设计或其他内容
@if($errors->any()) <h4>{{$errors->first()}}</h4> @endif