php - codeigniter result_array 无法在真实服务器上运行

标签 php mysql sql database codeigniter

我正在使用数据库开发 codeigniter 项目,它在本地主机上运行得很好,但是当我将其上传到真实服务器上时,出现了很多问题。

我确实进行了很多搜索,但找不到解决方案。

当我从数据库检索数据并给出此错误时,result_array() 函数不起作用“ fatal error :在/home/mostafa/public_html/Sales 中的非对象上调用成员函数 result()/application/models/m_login.php 第 13 行“

这是我的 Controller 代码

class c_login extends CI_Controller {
public function index() {
    $this->load->view('login');
}

public function signin(){
    $username = $this->input->post('username');
    $password = $this->input->post('password');

    $this->load->model('m_login');
    $user = $this->m_login->signin($username, $password);

    if(!$user){
        echo "<script>alert('Your Username Or Password is Incorrect');</script>";
    }else{

        //set session
        $userData = array(
            'id' => $user[0]['id'],
            'name'  => $user[0]['name'],
            'admin' => $user[0]['admin']
        );

        $this->session->set_userdata($userData);

        if ($user[0]['admin'] == 1) {
            redirect('c_home_admin');
        }else{
            redirect('c_home_user');
        }
    }
}

}

这是模型代码

class m_login extends CI_Model{
function insertUser($data) {
    $this->db->insert('users', $data);
}

public function signin($username, $password){
    $this->db->select('*')->from('users')->where(array('username' => $username, 'password' => $password));
    $query = $this->db->get();
    return $query->result_array();
}}

这是database.php配置:

$active_group = 'default';

$active_record = TRUE;

$db['default']['hostname'] = 'localhost';

$db['default']['username'] = 'root';

$db['default']['password'] = '**********';

$db['default']['database'] = 'mydb';

$db['default']['dbdriver'] = 'mysql';

$db['default']['dbprefix'] = '';

$db['default']['pconnect'] = TRUE;

$db['default']['db_debug'] = TRUE;

$db['default']['cache_on'] = FALSE;

$db['default']['cachedir'] = '';

$db['default']['char_set'] = 'utf8';

$db['default']['dbcollat'] = 'utf8_general_ci';

$db['default']['swap_pre'] = '';

$db['default']['autoinit'] = TRUE;

$db['default']['stricton'] = FALSE;

提前致谢

最佳答案

我要检查的第一件事是您的数据库架构在开发时与实际运行时是否完全相同。如果表不相同(例如缺少字段),您将收到该错误。

编辑

尝试按如下方式重写 SQL 查询:

$sql = "
    SELECT * FROM `users` where `username` = ? AND `password` = ?
";
$q = $this->db->query($sql, array($username, $password));
return $q->result_array();

(抱歉 - 将其发布在我的答案中,因为评论看起来很奇怪......)

关于php - codeigniter result_array 无法在真实服务器上运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19962099/

相关文章:

sql - Oracle 12c 文档,了解 SQL 的更改/新特性

php - 获取特定产品的所有父类别

php - 查看未找到 Laravel

php - 努力在数据库字段中存储加密信息

c# - 如何从sql日期中删除时间

sql - 如何查询 Intersystems Caché 以获取命名空间、数据库和表的列表?

php - 如何添加 1 个表中多行中的多列以及另一个表中的 1 行?

php - 检查 Memcache 中是否存在键

php - 使用条件更新查询管理并发

php - CPanel不允许使用脚本创建文件?