CodeIgniter 4项目中的常量“CodeIgniter\数据库\MySQLi\MYSQLI_STORE_RESULT”未定义

ubof19bj  于 2022-12-06  发布在  Mysql
关注(0)|答案(2)|浏览(170)

我有CodeIgniter项目(4.1.5)与Composer一起安装。我正在PHP 8.0.12上运行它
当我尝试与数据库通信时,收到内部服务器错误500,日志消息如下:

CRITICAL - 2021-11-13 01:39:18 --> Undefined constant "CodeIgniter\Database\MySQLi\MYSQLI_STORE_RESULT"
#0 D:\Sites\ea4\vendor\codeigniter4\framework\system\Database\Database.php(56): CodeIgniter\Database\Database->initDriver('MySQLi', 'CodeIgniter\\Dat...', Array)
#1 D:\Sites\ea4\vendor\codeigniter4\framework\system\Database\Config.php(78): CodeIgniter\Database\Database->load(Array, 'default')
#2 D:\Sites\ea4\vendor\codeigniter4\framework\system\Model.php(97): CodeIgniter\Database\Config::connect('default')
#3 D:\Sites\ea4\app\Controllers\Backend\Home.php(33): CodeIgniter\Model->__construct()
#4 D:\Sites\ea4\vendor\codeigniter4\framework\system\CodeIgniter.php(824): App\Controllers\Backend\Home->index()
#5 D:\Sites\ea4\vendor\codeigniter4\framework\system\CodeIgniter.php(410): CodeIgniter\CodeIgniter->runController(Object(App\Controllers\Backend\Home))
#6 D:\Sites\ea4\vendor\codeigniter4\framework\system\CodeIgniter.php(318): CodeIgniter\CodeIgniter->handleRequest(NULL, Object(Config\Cache), false)
#7 D:\Sites\ea4\public\index.php(37): CodeIgniter\CodeIgniter->run()

在Home控制器中,我有以下代码:

public function index()
{
    $session = session();
    $data = [];
    // Check for post
    if ($this->request->getMethod() === 'post') {
        // Validate the user input
        if (!($this->validate([
            'cmsuserEmail'      => ['label' => 'E-Mail',                'rules'   => 'required|min_length[6]|max_length[50]|valid_email'],
            'cmsuserPassword'   => ['label' => 'Κωδικός πρόσβασης',     'rules'   => 'required|min_length[8]|max_length[255]'],
        ]))) {
            // Validation has failed, redirect the user back
            return redirect()->to(base_url() . '/Backend/Home/index')->withInput();
        }
        $model = new CmsuserModel();
        $user = $model->where('cmsuserEmail', $this->request->getPost('cmsuserEmail'))->first();
        // If I try to var_dump user, var_dump is not displayed, if I print string "Debug" and die()  one line above, string is printed.

有人知道为什么我会得到这个错误吗?我应该定义常量MYSQLI_STORE_RESULT吗?在哪里?

rkttyhzu

rkttyhzu1#

据我所知,您可以检查是否安装了PHP的mysqli模块。
通过服务器cli上的php -m进行检查,您应该将mysqli列为其中一个模块。
我检查了这里的引用https://www.php.net/manual/en/mysqli.installation.php
我在Docker上托管的CodeIgniter 4文件上使用了这个,我也得到了这个错误。经过一些研究,我只是在映像构建中确保PHP的mysqli模块正在安装/已安装。

arknldoa

arknldoa2#

在我的例子中,我取消了php.ini中的extension=mysqliextension_dir="ext"以及php/ext文件夹中的php_mysqli. dll文件的注解,我只是删除了php.ini中extension=mysqliextension_dir="ext"行上的;:然后使用终端上的php -m检查mysqli是否在模块列表中。
第一个

相关问题