Управление двумя ролями в codeigniter

0

У меня две роли: админ и учитель. Учетные записи администратора и учителя могут войти в систему, однако, когда я зарегистрирую учетную запись учителя, она перенаправится на страницу администратора. Я не знаю, правильно ли работает мой код. Я новичок в использовании codeigniter, поэтому, пожалуйста, несите меня.

Итак, вот мой контроллер:

public function login_validation(){

  $this->load->library('form_validation');


  $this->form_validation->set_rules('idnum', 'ID Number', 'required|trim|xss_clean|callback_validate_credentials');
  $this->form_validation->set_rules('password', 'Password', 'required|md5|trim');

  if ($this->form_validation->run()){
     //$this->load->model('model_users');
     $this->load->model('model_role');
     $data = array(
           'login_id' => $this->input->post('idnum'),
           'is_logged_in' => 1,
             'role' => $this->model_role->scalar('user_account','role')

        );

     $this->session->set_userdata($data);
     redirect('site/members'); 
  } else {
     $data['title'] = "Outcome-based Education";

     $this->load->view("index/header", $data);
     $this->load->view("index/view_home");
     $this->load->view("index/footer");
  }
}

public function members(){

  if($this->session->userdata('is_logged_in') && $this->session->userdata('role', 'admin')){
     $this->load->view('login/admin');
  }  elseif($this->session->userdata('is_logged_in') && $this->session->userdata('role', 'teacher')){
     $this->load->view('login/members');
  } 

     else{  
     redirect('site/restricted');
  }
}

И это моя модель:

public function can_log_in(){

        $this->db->where('login_id', $this->input->post('idnum'));
        $this->db->where('password', md5($this->input->post('password')));

        $query = $this->db->get('user_account');

        if($query->num_rows() == 1){
            return true;
        } else{
            return false;
        }
    }
  • 0
    Итак, каков твой вопрос? :)
Теги:
codeigniter

2 ответа

0
Лучший ответ

В функции ваших членов вы фактически не проверяете значение данных сеанса роли, вы просто проверяете, что она существует. Вам нужно изменить:

if($this->session->userdata('is_logged_in') && $this->session->userdata('role', 'admin')){

чтобы:

if($this->session->userdata('is_logged_in') && $this->session->userdata('role') == 'admin'){

Как вы увидите, есть только один параметр, который можно передать в функцию $this-> session-> userdata():

/**
 * Fetch a specific item from the session array
 *
 * @access  public
 * @param   string
 * @return  string
 */
function userdata($item)
{
    return ( ! isset($this->userdata[$item])) ? FALSE : $this->userdata[$item];
}
  • 0
    Спасибо за ваш ответ. Тот, на который вы ответили, действительно сработал. Еще раз спасибо.
0

когда вы выполняете действие входа в систему, откуда вы вызываете метод модели can_log_in(), даже если вы загружаете модель, но вы вызываете только метод $this-> model_role-> scalar ('user_account', 'role'), который вы даете только Параметр "admin" приводит к ответу.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню