我在根据类型重定向用户时遇到问题。怎么办这里是我的代码,请建议如何做。
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
class VerifyLogin extends CI_Controller {
function __construct()
{
parent::__construct();
}
function index()
{
$this->load->model('user','',TRUE);
//This method will have the credentials validation
$this->load->library('form_validation');
$this->load->library('session');
$this->form_validation->set_rules('username', 'Username','trim|required|xss_clean');
$this->form_validation->set_rules('password', 'Password'
'trim|required|xss_clean|callback_check_database');
if($this->form_validation->run() == FALSE)
{
//Field validation failed. User redirected to login page
validation_errors();
$this->load->view('error');
}
else
{
//Go to private area
基本上在这里我想重定向如果用户是管理员然后重定向到管理页面,否则重定向到主页。我怎么能这样做?
redirect('home', 'refresh');
}
}
function check_database($password)
{
//Field validation succeeded. Validate against database
$username = $this->input->post('username');
//query the database
$result = $this->user->login($username, $password);
if($result)
{
$sess_array = array();
foreach($result as $row)
{
$sess_array = array(
'id' => $row->id,
'username' => $row->username
);
$this->session->set_userdata('logged_in', $sess_array);
}
return TRUE;
}
else
{
$this->form_validation->set_message('check_database', 'Invalid username or password');
return false;
}
}
}
?>
答案 0 :(得分:1)
我这样做的方法是通过角色表加入用户。每个用户都被分配到一个角色(例如销售人员,会计经理等)。每个角色都有一个可选主页,可在登录后重定向到该主页。如果未设置,则会重定向到默认页面。
答案 1 :(得分:1)
好吧,你说你有登录功能,所以这里是基础知识。 Mike所说的是对的以及我是如何做到的,但如果你只有两种类型的用户,那么角色解决方案可能有点过头了。我个人使用角色填充用户菜单,所有用户都获得相同的菜单,选项会根据他们允许看到的网站部分而改变。
对于基本的管理员/用户,尽管这不是必需的。您需要做的只是在登录后基于用户组重定向,所以类似于此。
$this->db->where(username, $username);
$this->db->where(password, $password);
$query = $this->db->get(users);
if($query->num_results() ==1)
{
$result = $query->result_array();
switch ($result['usergroup']) {
case '1':
redirect 'home';
break;
case '2':
redirect 'admin';
break;
default:
redirect 'home';
break;
}
}
正如我所说,这是一个基本的解决方案,你可以用于几个不同的角色,如果你想做更复杂的事情调查创建角色。
您还希望将用户组保存到会话中,并在管理页面上进行检查,如果用户不是管理员,则将其重定向到页面之外。