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 в таблице пользователей в базе данных, это работает для меня.

Другие вопросы по тегам