在codeigniter中管理两个角色

时间:2014-11-24 00:04:33

标签: php codeigniter

我有两个角色,即管理员和老师。管理员和教师帐户可以登录,但是当我登录教师帐户时,它将重定向到管理员页面。我不知道我的代码是否正确。我是使用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;
        }
    }

2 个答案:

答案 0 :(得分:0)

当您执行登录操作时,从您调用can_log_in()方法的模型,即使您加载模型,但您只调用$ this-> model_role->标量(' user_account' ,'角色')方法,你只给" admin"参数导致响应。

答案 1 :(得分: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];
}