我试过搜索谷歌并尝试了几种方法 . 他们都没有工作: 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 回答
我很确定你的错误在这里:
数据库中的
password
字段是小写的,您正在检查以大写P
开头的字段 . 将'Password' => $request->password
更改为'password' => $request->password
,它应该有效 .我的不好,包括用户模型中的以下代码帮助我解决问题 .