Heim  >  Fragen und Antworten  >  Hauptteil

So überprüfen Sie, ob das eingegebene Passwort mit dem Datenbank-Hash-Passwort in Laravel 8 übereinstimmt

<p>Wie überprüfe ich das Benutzerpasswort aus einer bestimmten Anfrage in Laravel? Wie wird das Passwort mit dem in der Datenbank gespeicherten Passwort-Hash verglichen? ** Das ist mein Controller **</p> <pre class="brush:php;toolbar:false;"><?php Namespace AppHttpControllers; benutze IlluminateHttpRequest; verwenden Sie IlluminateSupportFacadesDB; Die Klasse MainController erweitert Controller { Funktion login1(Request $request){ $username = $request->input('username'); $password = $request->input('password'); $data = DB::table('users')->where(['username'=>$username, 'password'=>$password])->first(); if($data == null){ echo „Fehler“; $notification = array( 'message' => 'Der Benutzer existiert nicht! ', 'alert-type' => 'error' ); return back()->with($notification); } anders{ $request->session()->put('user',$data); Return Redirect('Dashboard'); } }}</pre></p>
P粉129731808P粉129731808390 Tage vor450

Antworte allen(2)Ich werde antworten

  • P粉373990857

    P粉3739908572023-08-29 00:51:27

    像这样

    $encrypted = Crypt::encrypt('password_name_variable');

    Antwort
    0
  • P粉071559609

    P粉0715596092023-08-29 00:50:53

    基本上,你想要做的是:

    1. 查询users表中具有给定用户名的用户。
    2. 检查他们的哈希密码是否与提供的密码的哈希相匹配。

    所以,你想要首先查询具有给定用户名的用户。然后,在检索到用户并验证其存在之后,你可以检查提供的密码是否与检索到的模型上的哈希密码匹配。

    public function login(Request $request): Response
    {
        $user = User::where('username', $request->get('username'));
    
        if (!$user || !Hash::check($request->get('password'), $user->password)) {
            return back()->with([
                'message' => '用户名和/或密码不正确。',
                'alert-type' => 'error'
            ]);
        }
    
        $request->session()->put('user', $user);
    
        return redirect('dashboard');
    }
    

    然而,在Laravel中有内置的功能可以实现这一点,根据你的需求,这样做可能更简单:

    public function login(Request $request): Response
    {
      if (!Auth::attempt(['username' => $request->get('username'), 'password' => $request->get('password')]) {
            return back()->with([
                'message' => '用户名和/或密码不正确。',
                'alert-type' => 'error'
            ]);
        }
    
        return redirect('dashboard');
    }

    https://laravel.com/api/8.x/Illuminate/Support/Facades/Auth.html#method_attempt

    Antwort
    0
  • StornierenAntwort