为了账号安全,请及时绑定邮箱和手机立即绑定

如何验证密码是否与数据库中的密码相同?

如何验证密码是否与数据库中的密码相同?

PHP
倚天杖 2023-09-22 15:00:05
我在 Laravel 中有登录表单,它使用电子邮件和密码登录网站。我已经进行了所有验证,除了密码之外一切正常。当我输入错误的密码时,它会进入空白页,我想在密码字段下写一些错误。我查看了相同的内容:密码验证,但它不起作用。任何帮助表示赞赏。这是我的代码。登录控制器.phppublic function login(Request $request){    $rules = [        'email'    => 'required|email|exists:App\User,email',         'password' => 'required|alphaNum|min:5'    ];    $validator = Validator::make($request->all(), $rules);    if ($validator->fails()) {        $request->session()->put('data', $request->input());        return redirect()->route('login')            ->withErrors($validator->errors())            ->withInput($request->session()->put('data', $request->input()));    } else {       $userData = array(            'email'     => $request->get('email'),            'password'  => $request->get('password')        );    }        if (Auth::attempt($userData)) {        return redirect()->route('dashboard');    } else {                redirect()->route('login');    }}登录.blade.php<div class="login-page">    <div class="login-box">        <div class="card mb-0">            <div class="card-body login-card-body">                <p class="login-box-msg font-weight-bold">Sign in to start your session</p>                <form method="POST" class="mb-4" action="{{route('login') }}">                    @csrf                    <div class="input-group mb-3">                        <input id="email" type="email" placeholder="Email" class="form-control @error('email') is-invalid @enderror" name="email" value="{{ old('email') }}" required autocomplete="email" autofocus>                        <div class="input-group-append">                            <div class="input-group-text">                                <span class="fas fa-user"></span>                            </div>                        </div>                        @error('email')                        <span class="invalid-feedback" role="alert">                            <strong>{{ $message }}</strong>                        </span>                        @enderror
查看完整描述

1 回答

?
蓝山帝景

TA贡献1843条经验 获得超7个赞

假设您的电子邮件是unique,您首先必须获取其所在的数据库行$request->email$user = User::where('email', $request->email)->first()

然后您可以使用以下方法进行检查:Hash::check($request->password, $user->password)

https://laravel.com/docs/7.x/hashing

@编辑

要将其添加到规则中,您必须创建一个规则类:php artisan make:rule myRuleName 然后您将这样调用它:

$rules = [
       'email'    => 'required|email|exists:App\User,email', 
        'password' => ['required','alphaNum','min:5', new myRuleName()],
    ];

在您的自定义规则类中,您将找到一个passes($attribute, $value)函数。现在你可以将我上面编写的代码插入到这个方法中。你必须替换$request->password$value


查看完整回答
反对 回复 2023-09-22
  • 1 回答
  • 0 关注
  • 106 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信