<p>我在Laravel中遇到了用户认证和显示验证消息的困难。当尝试登录时,用户无法正确通过身份验证,并且验证错误消息也没有显示。</p>
<p>我按照官方的Laravel文档进行了认证和验证,但即使在人工智能的帮助下,我也没有得到预期的结果。以下是我的一些代码片段:</p>
公共函数存储(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>
您最初验证了电子邮件和密码,这是很好的。登录失败后,您抛出了一个异常,这就是为什么它不会将您重定向到登录页面的原因。所以应该重定向到带有错误的上一页。
因此,将store方法修改如下:
现在,在登录页面的blade文件中使用以下代码,这将打印错误。根据需要修改设计或其他内容