搜索

首页  >  问答  >  正文

Laravel中验证用户身份和显示验证消息时遇到问题

<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>
P粉071626364P粉071626364486 天前713

全部回复(1)我来回复

  • P粉502608799

    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

    回复
    0
  • 取消回复