4

私はcodeigniterに取り組んでおり、ログイン機能のためにコントローラーにフォームを送信するログインビューがありますが、取得した応答は302 Foundであり、ログインページにリダイレクトされます。

私のコントローラーコードは

class super_admin extends CI_Controller
{

    public function index()
    {
        $this->load->view('admin/login_view');
    }

    function checkLogin()
    {
        $email = mysql_real_escape_string($_POST['email']);
        $pwd = mysql_real_escape_string($_POST['pwd']);

        $this->load->model('admin/admin_model');
        $user = $this->admin_model->checkUser($email);
        //print_r($user[0]);
        if ($user && ($user[0]->password == md5($pwd)))
        {

            $user_data = array(
                            'user_id' => $user[0]->user_id,
                            'user_name' => $user[0]->name,
                            'user_email' => $user[0]->email
                        );

            $this->session->set_userdata($user_data);
            $this->load->view('admin/dashboard_view',$user_data);
        }
        else
        {
            $this->session->set_flashdata('invalid', '<div class="alert alert-error" id="invalid" ><h6>Invalid Email or Password</h6></div>');
            redirect('admin/super_admin');
        }
    }
}

どうすればこれを修正できますか?

4

1 に答える 1

0

リダイレクトを使用してフォームを送信するメソッドでビューをロードしないでください。そうしないと、ページを更新したときに投稿リクエストが取得されず、条件が false を返し、誤動作の原因となります。この回避策を試してください。$user 変数の内容も確認してください。

class super_admin extends CI_Controller
{

    public function index()
    {
        $this->load->view('admin/login_view');
    }

    function checkLogin()
    {
        $email = $this->input->post('email', TRUE);
        $pwd = $this->input->post('pwd', TRUE);

        $this->load->model('admin/admin_model');
        $user = $this->admin_model->checkUser($email);
        //print_r($user[0]);
        if ($user && ($user[0]->password == md5($pwd)))
        {

            $user_data = array(
                            'user_id' => $user[0]->user_id,
                            'user_name' => $user[0]->name,
                            'user_email' => $user[0]->email
                        );

            $this->session->set_userdata($user_data);
            redirect('super_admin/dashboard');
        }
        else
        {
            $this->session->set_flashdata('invalid', '<div class="alert alert-error" id="invalid" ><h6>Invalid Email or Password</h6></div>');
            redirect('admin/super_admin');
        }
    }

    function dashboard()
    {
       if( $this->session->userdata('user_id') ) {
         $user_data = $this->session->all_userdata();
         $this->load->view('admin/dashboard_view',$user_data);
       } else {
         redirect('admin/super_admin');
       }
    }
}
于 2012-11-26T06:46:33.013 に答える