首页 > 解决方案 > 登录尝试 - Codeigniter - 不工作

问题描述

我想锻炼一个功能,使用户的不成功登录尝试被限制为连续 3 次失败的登录尝试,然后向他们发送一条消息。它立即执行这一行:

if ($isBlocked) {
    $this->form_validation->set_message('check_user', 'Account is temporarily blocked.');
}

我的代码有问题。在此先感谢您的帮助。

控制器

<?php
class Account_login extends CI_Controller
{
  public function __construct()
  {
    parent::__construct();
  }

  public function index()
  {
    $data['title'] = 'Account Login';
    $this->load->view('account_login', $data);
  }

  public function verify()
  {
    $this->form_validation->set_rules('acc_username', 'Username', 'required');
    $this->form_validation->set_rules('acc_password', 'Password', 'required|callback_check_user');

    if ($this->form_validation->run() === TRUE) {
      echo 'Success';
    } else {
      $this->index();
    }
  }

  public function check_user()
  {
    $username = $this->input->post('acc_username');
    $password = $this->input->post('acc_password');


    $this->load->model('account_login_model');
    $login = $this->account_login_model->login($username, $password);


    if ($login) {
      return true;
    } else {
      if (isset($_SESSION['error_count'][$username])) {
        $_SESSION['error_count'][$username] += 1;
      } else {
        $_SESSION['error_count'][$username] = 1;
      }

      $isBlocked = $this->account_login_model->isBlocked($username);
      if ($isBlocked) {
        $this->form_validation->set_message('check_user', 'Account is temporarily blocked.');
      } else if (isset($_SESSION['error_count'][$username]) && $_SESSION['error_count'][$username] > 2) {
        $this->account_login_model->block($username);
        $this->form_validation->set_message('check_user', '3 consecutive failed login attempts. Account Blocked.');
      } else {
        $this->form_validation->set_message('check_user', 'Invalid Username/Password');
      }
      return false;
    }
  }
}

模型

<?php
class account_login_model extends CI_Model
{
  public function __construct()
  {
    parent::__construct();
    $this->load->database();
  }

  public function login($username, $password)
  {
    $condition_array = array(
      'acc_username' => $username,
      'acc_password' => $password
    );
    $rs = $this->db->get_where('accounts', $condition_array);

    return $rs->row_array() ?: false;
   
  }

  public function isBlocked($username)
  {
    $condition_array = array(
      'acc_username' => $username,
      'acc_isBlocked' => 1
    );
    $rs = $this->db->get_where('accounts', $condition_array);
    $row_count = count($condition_array);

    if ($row_count > 0) {
      return true;
    } else {
      return FALSE;
    }
  }

  public function block($username)
  {
    $this->load->library('email');

    $email = $this->account_lookup($username, 'acc_email');

    $this->email->from('<email>', 'Yahoo.com');
    $this->email->to($email);
    $this->email->subject('Account Blocked');

    $message = $this->load->view('account_blocked', null, TRUE);

    $this->email->message($message);
    $this->email->send();

    $this->db->where('acc_username', $username);
    return $this->db->update('accounts', array('acc_isBlocked' => 1));
  }

  public function account_lookup($username, $return)
  {
    $rs = $this->db->get_where('account', array('acc_username' => $username));
    $row = $rs->row();
    return $row->$return;
  }
}

标签: phpcodeigniter

解决方案


推荐阅读