0

誰かがログインしている場合、このコードはセッションをチェックし、ページを正常に表示できますが、ユーザーが管理者であるかどうかを確認したいと思います。モデルをチェックインしようとしました 以下は私が試したことであり、機能していません。

セッションをチェックし、それが管理者かどうかを確認するメソッド

public function index()
{
    $this->load->library('authlib');
    $loggedin = $this->authlib->is_loggedin();
    ///$admin = $this->auth->admin();

    if ($loggedin === false) {
    $this->load->helper('url');
    redirect('/auth/login');
    }
    if ($this->auth->admin() === false) {
    $message ['msg'] = "You are not an admin!";
    $this->load->view('homeview', $message);
    }
    else
    {
    $this->load->view('add_view');
    }
}

認証コントローラー

public function authenticate()
{
$username = $this->input->post('uname');
$password = $this->input->post('pword');
$user = $this->authlib->login($username,$password);
**>> $this->admin($username,$password); << passes the posted in values**
if ($user !== false) {
    $this->load->view('homeview',array('name' => $user['name']));

}
else {
    $data['errmsg'] = 'Unable to login - please try again';
    $this->load->view('login_view',$data);
}   
}

public function admin($username,$password){
//$this->load-model('usermodel');
$admin = $this->authlib->adminlib($username,$password);
if ($admin == false){
return false;
//if ($res->num_rows() != 1){
//return false;
}
}

ライブラリ authlib

public function adminlib($user,$pwd) 
{
return $this->ci->usermodel->chkadmn($user,$pwd);
}

モデル

function chkadmn($username,$password)
{
$this->db-where(array('username' => $username,'password' => sha1($password)));
$res = $this->db->get('users',array('type'));
if ($res->num_rows() != 1) {
return false;
}
}

いくつかの変更を加えたところ、「54 行目の C:\xampp\htdocs\ecwm604\application\models\usermodel.php の未定義関数 where() への呼び出し」が表示されます。

4

1 に答える 1

0

個人的には、すべての if ステートメントを置き換えて、次のようにテストします。

  public function index()
    {
        $this->load->library('authlib');
        $loggedin = $this->authlib->is_loggedin();
        ///$admin = $this->auth->admin();

        if (!$loggedin) {
        $this->load->helper('url');
        redirect('/auth/login');
        }

        if (!$this->auth->admin()) {
        $message ['msg'] = "You are not an admin!";
        $this->load->view('homeview', $message);
        }
        else
        {
        $this->load->view('add_view');
        }

    }

    public function admin(){
    $this->load-model('usermodel');
    $admin = $this->usermodel->chkadmn($username,$password);
    if (!$admin){
    return false;
    //if ($res->num_rows() !== 1){
    //return false;
    }
    }

    function chkadmn($username,$password)
    {
    $this->db-where(array('username' => $username,'password' => sha1($password)));
    $res = $this->db->get('users',array('type'));
    if ($res->num_rows() !== 1) {
    return false;
    }
    }
于 2012-12-31T14:33:21.330 に答える