Yii2 без подтверждения по электронной почте пользователь не может войти
Когда пользователь регистрируется, система отправляет электронное письмо с подтверждением своей работы, но без какого-либо электронного подтверждения система автоматически входит в систему или пользователь может войти. Как я могу решить эту проблему, что пользователь должен подтвердить электронную почту перед входом в систему, и если пользователь не подтвердил, что пользователь электронной почты не может войти в систему?
Я использую этот проект: Yii 2 Advanced Template с Rbac User Managment
мой код модели LoginForm
namespace common\models;
use Yii;
use yii\base\Model;
/**
* Login form
*/
class LoginForm extends Model
{
public $email;
public $password;
public $rememberMe = true;
protected $_user = false;
/**
* @inheritdoc
*/
public function rules()
{
return [
// username and password are both required
['email', 'filter', 'filter' => 'trim'],
[['email','password'], 'required'],
['email', 'email'],
// rememberMe must be a boolean value
['rememberMe', 'boolean'],
// password is validated by validatePassword()
['password', 'validatePassword','skipOnEmpty'=>false],
];
}
/**
* Validates the password.
* This method serves as the inline validation for password.
*
* @param string $attribute the attribute currently being validated
* @param array $params the additional name-value pairs given in the rule
*/
public function validatePassword($attribute, $params)
{
if (!$this->hasErrors()) {
$user = $this->getUser();
if (!$user || !$user->validatePassword($this->$attribute)) {
$this->addError('email', Yii::t('messages','Incorrect password or email.'));
$this->addError('password', Yii::t('messages','Incorrect password or email.'));
}
}
}
/**
* Logs in a user using the provided username and password.
*
* @return boolean whether the user is logged in successfully
*/
public function login()
{
if ($this->validate()) {
return Yii::$app->user->login($this->getUser(), $this->rememberMe ? 3600 * 24 * 30 : 0);
} else {
return false;
}
}
/**
* Finds user by [[username]]
*
* @return User|null
*/
public function getUser()
{
if ($this->_user === false) {
$this->_user = User::findByEmail($this->email);
}
return $this->_user;
}
public function attributeLabels()
{
return [
'email' => Yii::t('app','Email'),
'password' => Yii::t('app','Password')
];
}
}
5 ответов
Найти ниже функцию в общем /models/User.php
public static function findByEmail($email)
{
return static::findOne(['email'=>$email,'status'=>self::STATUS_ACTIVE]);
}
и заменить его следующим
public static function findByEmail($email)
{
return static::findOne(['email'=>$email,'status'=>self::STATUS_ACTIVE,'email_verification_status'=>self::EMAIL_VERIFIED]);
}
Надеюсь, что это поможет вам
Это происходит потому, что статус электронной почты по умолчанию неактивен, для изменения этого статуса вы можете перейти на
общий / модель /user.php
и изменить функцию правила от
public function rules()
{
return [
['status', 'default', 'value' => self::STATUS_INACTIVE],
['status', 'in', 'range' => [self::STATUS_ACTIVE, self::STATUS_INACTIVE, self::STATUS_DELETED]],
];
}
в
public function rules()
{
return [
['status', 'default', 'value' => self::STATUS_ACTIVE],
['status', 'in', 'range' => [self::STATUS_ACTIVE, self::STATUS_INACTIVE, self::STATUS_DELETED]],
];
}
удачи
Изменение статуса на бэкэнде (таблица пользователей) на 10 работало как шарм
Вам необходимо настроить SMTP для проверки электронной почты, но для localhost вы можете использовать следующие шаги.
- В каталоге @ frontend / runtime / mail есть имя файла, например 2021XXXX-162725-6907-8769.eml .
- Откройте его и нажмите на ссылку в нем, а затем вы получите сообщение «Ваше электронное письмо подтверждено!» в вашем веб-браузере.
- Теперь ваш адрес электронной почты подтвержден, и вы можете перейти к входу в систему.
Используйте sataus = 10 в таблице пользователей в базе данных, это работает для меня.