最近、ユーザーがサインアップして自分のアカウントを作成できる登録ページを作成しました。しかし、ログアウトしてからアカウントに戻ってログインしようとすると、暗号化されたパスワードのみが受け入れられます。loguserin 関数をデータベースと通信させ、それが実際にはユーザーが最初に入力した通常のパスワードであることを認識させるにはどうすればよいですか?
コントローラ:
function loguserin()
{
$this->load->helper(array('form', 'url'));
$this->load->library('form_validation');
$this->form_validation->set_rules('username', 'Username', 'required|min_length[4]|max_length[12]|callback_validateUser|trim');
$this->form_validation->set_rules('password', 'Password', 'required|md5|trim');
if ($this->form_validation->run())
{
$username = $this->input->post('username');
$password = $this->input->post('password');
$this->session->set_userdata('status', 'OK');
$this->session->set_userdata('username', $username);
redirect('home');
}
else
{
$this->session->set_userdata('status', 'NOT_OK');
$this->load->view('shared/header');
$this->load->view('account/logintitle');
$this->load->view('account/loginview');
$this->load->view('shared/footer');
}
}
function validateUser($username, $password)
{
$this->db->select('*')->from('membership');
$this->db->where('username', $username);
$this->db->where('password',MD5($password));
$query = $this->db->get();
if ($query ->num_rows ==1)
{
$this->form_validation->set_message('validateUser', 'Invalid username/password');
return false;
}
else{
return true;
}
}