Php 如何登录codeigniter?
我有语法,我认为语法已经正确了,但是当我在浏览器中运行登录时,登录名并没有进入成功页面。登录只需在Php 如何登录codeigniter?,php,codeigniter-3,Php,Codeigniter 3,我有语法,我认为语法已经正确了,但是当我在浏览器中运行登录时,登录名并没有进入成功页面。登录只需在表单\u login中重复。如果我输入的用户名和密码错误都是相同的nothing通知错误。我的语法怎么了 这是控制器 function __construct() { parent::__construct(); $this->load->model('account/user_model'); // $this->load->helpe
表单\u login
中重复。如果我输入的用户名和密码错误都是相同的nothing通知错误。我的语法怎么了
这是控制器
function __construct()
{
parent::__construct();
$this->load->model('account/user_model');
// $this->load->helper('url');
// $this->load->helper('form');
$this->load->library('form_validation');
//tambahin library session supaya mau jalan
$this->load->library('session');
//atau di taruh di autoload
}
//melihat halaman login
public function index()
{
$this->load->view('account/form_login');
}
//memeriksa keberadaan akun username
public function login()
{
$username = $this->input->post('username','true');
$password = $this->input->post('password','true');
$temp_account = $this->user_model->check_user_account($username,$password)->row();
//check account
$num_account = count($temp_account);
$this->form_validation->set_rules('username','username','required');
$this->form_validation->set_rules('password','password','required');
if($this->form_validation->run()==FALSE)
{
$this->load->view('account/form_login');
}
else {
if ($num_account > 0) {
//kalau ada set session
$array_items = array(
'id_user' => $temp_account->id_user,
'username' => $temp_account->username,
'logged_in' => true
);
$this->session->set_userdata($array_items);
redierct(site_url('account/success_page'));
} else {
//kalau ga ada diredirect lagi ke halaman login
$this->session->set_flashdata('notification', 'Peringatan : Username dan Password tidak cocok');
redirect(site_url('account'));
}
}
}
public function view_success_page()
{
$logged_in = $this->session->userdata('logged_in');
if(!$logged_in)
{
redirect(site_url('account'));
}
$this->load->view('account/success_page');
}
这是html登录
<?php echo validation_errors();?>
<p style="color:red"><?php echo $this->session->flashdata('notification')?></p>
<?php echo form_open('account/login')?>
Username : <input typer="text" name="username" value="<?php echo set_value('username')?>"/>
<br>
<br>
Password : <input type="password" name="password" value="<?php echo set_value('password')?>"/>
<br>
<br>
<input type="submit" name="masuk" value="LOGIN"/>
<br>
使用Ion Auth 3库
让你更容易
但是:
型号:
function check_user_account($username,$password)
{
$this->db->select('*');
$this->db->from('user');
$this->db->where('username',$username);
$this->db->where('password',$password);
$q = $this->db->get();
if ($q->num_rows() > 0) {
return $q->row();
} else
return FALSE;
}
很抱歉,我没有足够的时间来测试,但我认为它现在正在工作
public function login()
{
$this->form_validation->set_rules('username','username','required');
$this->form_validation->set_rules('password','password','required');
if($this->form_validation->run()==true)
{
$username = $this->input->post('username','true');
$password = $this->input->post('password','true');
$temp_account = $this->user_model->check_user_account($username,$password);
//check account
if ($temp_account) {
//kalau ada set session
$array_items = array(
'id_user' => $temp_account->id_user,
'username' => $temp_account->username,
'logged_in' => true
);
$this->session->set_userdata($array_items);
redierct(site_url('account/success_page'));
} else {
//kalau ga ada diredirect lagi ke halaman login
$this->session->set_flashdata('notification', 'Peringatan : Username dan Password tidak cocok');
redirect(site_url('account'));
}
}
else {
$this->load->view('account/form_login');
}
}
function check_user_account($username,$password)
{
$this->db->select('*');
$this->db->from('user');
$this->db->where('username',$username);
$this->db->where('password',$password);
$q = $this->db->get();
if ($q->num_rows() > 0) {
return $q->row();
} else
return FALSE;
}