首页 文章

Laravel Auth ::尝试总是返回false

提问于
浏览
-1

我试过搜索谷歌并尝试了几种方法 . 他们都没有工作: auth::attempt 仍然返回false . 我的注册码如下;在我 AuthController 我有:

protected function create(array $data)
{
    $datetime = new \DateTime();
    $datetime->format('Y-m-d H:i:s');
    $datetime->getTimestamp();

    return User::create([
        'country_id' => 1, // default to malaysia
        'user_name' => $data['user_name'],
        'facebook_id' => null,
        'steam_link' => null,
        'password' => Hash::make($data['password']),
        'extra_information' => null,
        'remember_token' => null,
        'email' => $data['email'],
        'status_id' => 1, // active
        'is_verified' => false, // false
        'user_type_id' => 2, // normal user
        'account_status_id' => 1, // pending
        'confirmation_code' =>  str_random(30),
        'created_at' => $datetime
    ]);
}

 public function postRegister(Request $request)
 {
    $validator = $this->validator($request->all());

    if ($validator->fails()) {
        $this->throwValidationException(
            $request, $validator
        );
    }

    $user = $this->create($request->all());

    Mail::send('emails.registration_verification', ['user' => $user], function ($m) use ($user)
    {
        $m->from('no-reply@myapps.com', 'www.myapps.com');
        $m->to($user->email, $user->user_name)->subject('Verify your myappsaccount.');
    });

    return view('auth.registration_success')->with('user_name',$user->user_name)->with('email', $user->email);
}

public function emailVerification($confirmation_code)
{
    if (!$confirmation_code)
    {
        return Redirect::route('/errors/500');
    }

    $user = User::whereConfirmationCode($confirmation_code)->first();

    if (!$user)
    {
        return Redirect::route('/errors/500');
    }

    $user->account_status_id = 2; // active
    $user->confirmation_code = null;
    $user->save();

    return view('auth.verification_success')->with('user',$user);
}

public function postLogin(Request $request)
{
    $userdata = array(
        'email' => $request->email,
        'Password' => $request->password
    );

    if (Auth::attempt($userdata,true)) {
        echo 'test';
    }
    else {
        var_dump($userdata);
    }
}

我已经相应地删除了密码,我还将密码列从60更改为255,但登录仍然失败 .

预期的工作流程是用户注册,系统向他们发送电子邮件以进行验证 . 用户单击电子邮件中的链接将触发 emailVerification 方法 . 验证完成后,用户应该能够登录 .

我错过了什么吗?

2 回答

  • 1

    我很确定你的错误在这里:

    $userdata = array(
            'email' => $request->email,
            'Password' => $request->password
    );
    

    数据库中的 password 字段是小写的,您正在检查以大写 P 开头的字段 . 将 'Password' => $request->password 更改为 'password' => $request->password ,它应该有效 .

  • 0

    我的不好,包括用户模型中的以下代码帮助我解决问题 .

    public function getAuthPassword()
        {
            return $this->password;
        }
    

相关问题