簡體   English   中英

laravel 5身份驗證始終返回false

[英]laravel 5 Authentication always return false

我已經嘗試了一切,但我真的不知道我在哪里做錯了,但是每次我登錄時,它都會返回false。 這是將用戶存儲在數據庫中的方法:

public function store(CreateUserRequest $request)
    {
        $user = new User();

        $password = str_random(10);
        $password_hash = bcrypt($password);

        $new_user = $user->create([
            'first_name'=>$request->input('first_name'),
            'last_name'=>$request->input('last_name'),
            'email'=>$request->input('email'),
            'fone_number'=>$request->input('fone'),
            'password'=>$password_hash
        ]);

        $new_user->permissions()->create(UserPermission::$default);
        //send email to the user
        Mail::send('admin.emails.auth.new_user',['new_user'=>$new_user,'password'=>$password],function($message) use ($new_user){
            $message->to($new_user->email)
                    ->from('lilgaetan88@gmail.com','Admin Pedagogia')
                    ->subject("your password");
        });

        return redirect()->route('home')->with('Success',"mail sent");

    }

登錄控制器

public function postLogin(LoginRequest $request){

        $remember = ($request->has('remember')) ? true : false;

         if(Auth::attempt($request->only(['email','password']),$remember)){
             return redirect()->intended('/home');
        }

           return redirect()->route('login')->with('fail','email or password incorrect');
    }
}

login.blade.php文件:

<form class="login-form" action="{{route('post-login')}}" method="post">

            @if(Session::has('fail'))
                <div class="alert alert-danger">{{\Illuminate\Support\Facades\Session::get('fail')}}</div>
            @endif

            @if ($errors->has())
                <div class="alert alert-danger">
                    @foreach ($errors->all() as $error)
                        {{ $error }}<br/>
                    @endforeach
                </div>
            @endif

        <div class="login-wrap">
            <p class="login-img"><i class="fa fa-lock"> Login Page</i></p>
            <div class="input-group">
                <span class="input-group-addon"><i class="fa fa-envelope"></i></span>
                <input type="text" name="email" class="form-control" placeholder="E-mail" autofocus>
            </div>
            <div class="input-group">
                <span class="input-group-addon"><i class="fa fa-key"></i></span>
                <input type="password" name="password" class="form-control" placeholder="Password">
            </div>
            <label class="checkbox">
                <input type="checkbox" name="remember"> Se souvenir de moi
                <span class="pull-right "> <a href="#"> Mot de Passe Oublie?</a></span>
            </label>
            {!!Form::token()!!}
            <button class="btn btn-primary  btn-block" type="submit">Login</button>
        </div>
    </form>

當我dd(Hash :: check($ pssowrd,$ new_user-> password))時,它始終返回true,這意味着哈希密碼是正確的,但身份驗證仍然返回false

嘗試在第6行刪除remove bcrypt()方法。我認為密碼散列是在laravel中自動處理的,因此您不需要bcrypt($password)

一種可能的錯誤是,您應該將一個關聯數據數組發送給try方法; 不是索引數組。 所以我想如果您這樣做的話會很好用的,

    Auth::attempt(['email' => $request['email'], 'password' => $request['password']], $remember))

Php中的索引數組和關聯數組

Laravel Doc Auth :: attempt()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM