2013-01-03 2 views
1
나는 다음과 같은 컨트롤러는 관리자

CodeIgniter의 데이터를 게시 보고서 오류 500

class Admin extends CI_Controller { 

    public function __construct() { 
     parent::__construct(); 
     $this->load->model('admin_model'); 
    } 

    public function index() 
    { 
     $this->load->library('session'); 
     $this->load->database(); 
     if (!$this->session->userdata('user_id') || !$this->session->userdata('user_name')) 
     { 
      header("Location: /admin/login"); 
     } 
     else 
     { 
      $user_id = $this->session->userdata('user_id'); 
      $user_name = $this->session->userdata('user_name'); 
      if (!$this->admin_model->verify($user_id, $user_name)) 
       header("Location: /admin/login"); 
     } 
     $this->load->view('templates/header'); 
     $this->load->view('admin/index'); 
     $this->load->view('templates/footer'); 
    } 
    public function login() 
    { 
     $this->load->view('templates/header'); 
     $this->load->helper('form'); 
     $this->load->library('form_validation'); 
     $this->form_validation->set_rules('username', 'Username', 'required'); 
     $this->form_validation->set_rules('password', 'Password', 'required'); 
     if ($this->form_validation->run() == FALSE) 
     { 
      $data['run'] = false; 
     } 
     else if (!$this->admin_model->loginverify($this->input->post('username'), 
       $this->input->post('password'))) 
     { 
      $data['run'] = false; 
     } 
     else 
     { 
      $data['run'] = true; 
     } 
     $this->load->view('admin/login', $data); 
     $this->load->view('templates/footer'); 
    } 
} 

명명하고 난 Admin_model

class Admin_model extends CI_Model 
{ 
    public function __construct() { 
     parent::__construct(); 
     $this->load->database(); 
    } 
    public function verify($id, $name) 
    { 
     if (!is_numeric($id)) 
      return false; 
     else 
     { 
      $query = $this->db->get_where('users', array('id'=>$id, 'username'=>$name), 1); 
      if ($query->result()->num_rows() === 0) 
       return false; 
      else 
       return true; 
     } 
    } 
    public function loginverify($name, $pass) 
    { 
     $pass = md5($pass); 
     //$query = $this->db->get_where('users', array('username'=>$name, 'passwd'=>$pass), 1); 
     $query = $this->db->query("SELECT * FROM users WHERE username='$name' AND passwd='$pass' LIMIT 1"); 
     if ($query->result()->num_rows() === 0) 
      return false; 
     else 
      return true; 
    } 
} 

라는 다음과 같은 모델을 가지고 그리고 내 양식은 다음과 같다

:

<?php if (!$run) 
{ 
?> 
<form method="post" action="/admin/login"> 

<h5>Username</h5> 
<input type="text" id="username" name="username" value="" size="50" /> 

<h5>Password</h5> 
<input type="password" id="password" name="password" value="" size="50" /> 

<div><input type="submit" id="submit" name ="submit" value="Login" /></div> 

</form> 
<?php 

}else{ 
    echo "successfully login"; 
} 
?> 

제출할 때 빈 페이지가 표시되며 Chrome에서 네트워크를 검사 할 때 게시물이 표시됩니다. 500 내부 서버 오류가 발생했습니다. 나는 위의 주석 라인으로 get_where 할 수있는 직접 쿼리를 변경할 때

, 나는 오류 메시지가 여기 수동 양식을 사용하고 mysql_escape_string(): This function is deprecated; use mysql_real_escape_string() instead.

와 심각도 8192을 가지고 있지만, 내 CSRF는 false로 설정됩니다. 나는 form_open('admin/login')을 사용해 보았지만 그다음에는 localhost/?admin/login?으로 바뀌 었습니다.

나는이 모든 문제에 직면 해 있으며 나는 내가해야 할 일을 모른다. 주어진 도움을 주셔서 감사합니다.

+1

귀하는 error_reporting 설정은 무엇으로 header();을 사용하지? 500은 치명적 오류 일 가능성이 높지만 E_DEPRECATED를 볼 수 있습니다. 'error_reporting (E_ALL); ini_set ('display_errors', 1);' –

+0

그리고'.htaccess' 파일이 있어야합니다. 서버의 error_log와 관련된 오류를 확인하십시오. –

답변

0

양식은 그래서 난이 변경 제안 해 드릴, 어쩌면 올바른 URL을 가리키는되지 않은 : 다음 교체하려고

<form action="/admin/login"> 

<form action="<?php echo site_url('admin/login'); ?>"> 

로하는 모든 headers() methods :

header("Location: /admin/login"); 

redirect(site_url('admin/login'),'',302); 

sincerily는 CodeIgniter의