[英]Codeigniter error select query fails to check user input
I am new to codeigniter,and I am using 3.1.5 version. 我是Codeigniter的新手,正在使用3.1.5版本。 Below is my user login function.
以下是我的用户登录功能。
class Auth extends CI_Controller
{
public function login()
{
// Load Login View
$this->load->view('login');
// validate form
$this->form_validation->set_rules('username','Username','required');
$this->form_validation->set_rules('password','Password','required|min_length[5]');
if($this->form_validation->run()== true){
$username = $_POST['username'];
$password = $_POST['password'];
// check user in database
$this->db->select("*");
$this->db->from("users");
$this->db->where(array("username"=>$username,"password"=>$password));
$query = $this->db->get();
$user_data = $query->row();
// check if user exists or not
if($user_data->username){
// show temporary success message
$this->session->set_flashdata("success","User successfully logged in");
// set temporary sesstion variables
$_SESSION['user_logged'] = TRUE;
$_SESSION['username'] = $user_data->username;
}else{
$this->session->set_flashdata("error","Invalid username, user not exist");
}
}
}
When i provide user credentials like username and password I am getting the below error and not able to solve this. 当我提供用户名(如用户名和密码)时,出现以下错误,无法解决。
Severity: Notice
Message: Trying to get property of non-object
Filename: controllers/Auth.php
Line Number: 29
Backtrace:
File: D:\xampp\htdocs\ci315\application\controllers\Auth.php
Line: 29
Function: _error_handler
File: D:\xampp\htdocs\ci315\index.php
Line: 315
Function: require_once
The line number 29 exactly from here 行号29正是从这里开始
if($user_data->username){
// show temporary success message
$this->session->set_flashdata("success","User successfully logged in");
// set temporary sesstion variables
$_SESSION['user_logged'] = TRUE;
$_SESSION['username'] = $user_data->username;
}else{
$this->session->set_flashdata("error","Invalid username, user not exist");
}
If i comment the above section then there is no error. 如果我评论以上部分,则没有错误。 Please suggest me where I am doing wrong.
请建议我在哪里做错了。 Any help would be greatly appreciated, Thanks in advance.
任何帮助将不胜感激,在此先感谢。
Used below code this working fine. 在下面的代码中使用可以正常工作。 used if($query->num_rows() > 0) instead of if($user_data->username) and $query->row()->username instead of $user_data->username
使用if($ query-> num_rows()> 0)代替if($ user_data-> username)和$ query-> row()-> username代替$ user_data-> username
class Auth extends CI_Controller
{
public function login()
{
// Load Login View
$this->load->view('login');
// validate form
$this->form_validation->set_rules('username','Username','required');
$this->form_validation->set_rules('password','Password','required|min_length[5]');
if($this->form_validation->run()== true){
$username = $_POST['username'];
$password = $_POST['password'];
// check user in database
$this->db->select("*");
$this->db->from("users");
$this->db->where(array("username"=>$username,"password"=>$password));
$query = $this->db->get();
if($query->num_rows() > 0){
// show temporary success message
$this->session->set_flashdata("success","User successfully logged in");
// set temporary sesstion variables
$_SESSION['user_logged'] = TRUE;
$_SESSION['username'] = $query->row()->username;
}else{
$this->session->set_flashdata("error","Invalid username, user not exist");
}
}
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.