我正在运行安装了 php 5.5.3 的 apache2 本地开发服务器。出于某种原因,我收到了错误
Fatal error: Call to undefined function mysqli_stmt_get_result()
在我所有的页面上。我在 php 文档中读到 get_result() 方法需要 MySQL 本机驱动程序 (mysqlnd),但是在 MySQL 网站上它说“从 PHP 5.4 开始,mysqlnd 库是 php.net 编译时默认为所有 PHP MySQL扩展”。我已经尝试安装 php5-mysqlnd 并且当我这样做时会覆盖我以前的 mysql 和 mysqli conf 文件,导致我收到错误
Fatal error: Call to undefined function mysqli_connect()
当我重新安装 php5-mysql 时,它会删除 mysqlnd 包。我并不真正关心安装软件包我更想知道为什么 mysqlnd 在 PHP 5.5.3 中没有被识别为应有的软件包,我该如何启用它?提前致谢!
Ubuntu 13.10 上运行的 Apache 2 服务器:
[~]$ php5 --version
PHP 5.5.3-1ubuntu2 (cli) (built: Oct 9 2013 14:49:12)
Copyright (c) 1997-2013 The PHP Group
[~]$ mysql --version
mysql Ver 14.14 Distrib 5.5.34, for debian-linux-gnu (x86_64) using readline 6.2
编辑:
我已经将扩展添加到位于 /etc/php5/apache2/php.ini 的 php.ini 文件中。文件内容如下:
; If you wish to have an extension loaded automatically, use the following
; syntax:
;
; extension=modulename.extension
;
; For example, on Windows:
;
; extension=msql.dll
;
; ... or under UNIX:
;
; extension=msql.so
;
; ... or with a path:
;
; extension=/path/to/extension/msql.so
extension=/usr/lib/php5/20121212/curl.so
extension=/usr/lib/php5/20121212/json.so
extension=/usr/lib/php5/20121212/mysqli.so
extension=/usr/lib/php5/20121212/mysql.so
extension=/usr/lib/php5/20121212/mysqlnd.so