CodeIgniter - вызов функции-члена select () для необъекта - PullRequest
13 голосов
/ 30 ноября 2011

Я совершенно новичок в CodeIgniter. Это мой код:

class User_model extends CI_Model {

    function validate_user() {

        $this->db->select('*');
        $this->db->from('user');
        $this->db->where('username', $this->input->post('username'));
        $this->db->where('password', md5($this->input->post('password')));
        $validate_user = $this->db->get();

        if($validate_user->num_rows == 1) {
            return TRUE;
        }
    }
}

Я получаю эту ошибку в файле моей модели:

Call to a member function select() on a non-object

В настоящее время я использую CodeIgniter версии 2.1.0. Пожалуйста, помогите мне!

Ответы [ 3 ]

42 голосов
/ 01 декабря 2011

Я думаю, что вы должны загрузить библиотеку "базы данных". Первый способ - включить «базу данных» в ваше приложение / config / autoload.php

$autoload['libraries'] = array('database', 'session');

или в конструкторе вашего класса:

class User_model extends CI_Model { 

     public function __construct() 
     {
           parent::__construct(); 
           $this->load->database();
     }
}

Вы можете получить больше информации здесь: https://www.codeigniter.com/user_guide/database/connecting.html

4 голосов
/ 01 декабря 2011

Похоже, вы не придерживаетесь шаблона MVC.Вы должны передавать данные из вида -> контроллер -> модель.

Что касается отправки информации в базу данных, я почти уверен, что CI обрабатывает ввод xss и фильтра, но вы никогда не можете быть в этом уверены.

Также убедитесь, что вы загружаете свои модели в файл config / autoload.php или запускаете модель в функции контроллера __construct ()

<?php
    class User extends CI_Controller
    {
        public __construct()
        {
            parent::__construct();
            $this->load->model('User_model');
        }
    }

или

$autoload['model'] = array('User_model');

Так, например, в моем виде входа в систему я бы заставил CI создать необходимые поля.

<?php 
    echo form_open('admin');
    echo form_label('Username:', 'username');
    echo form_input('username', 'name');
    echo form_label('Password:', 'password');
    echo form_password('password');
    echo form_submit('submit', 'Login', 'id="loginBtn"'); ?>
    echo form_close(); 
?>

Теперь в контроллере

<?php
class User extends CI_Controller
{

    public function index()
    {

        $this->load->model('User_model');
        $result = $this
                    ->user_model
                    ->index(
                        $this->input->post('username'),
                        $this->input->post('password'));
    }

}
?>

И модель

<?php

class User_model extends CI_Model
{


    function index($username, $password)
    {
        $q = $this
                ->db
                ->where('username', $username)
                ->where('password', md5($password))
                ->limit(1)
                ->get('user');

        if ($q->num_rows() > 0) {
            return $q->row();
        }
    }
}
0 голосов
/ 30 ноября 2011

num_rows - это функция, поэтому вам нужно добавить ()

if($validate_user->num_rows() == 1) {
        return TRUE;
}

Кроме того, вы вызываете конструктор родительского класса в конструкторе

class User_model extends CI_Model {

    function __construct()
    {
        parent::__construct();
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...