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