我正在共享主机服务器上安装Roundcube 0.9.0。
我已经激活了PDO的PHP 5.3.8,但是当我安装roundcube时,这就是我得到的响应:
Check DB config
Fatal error: Undefined class constant 'MYSQL_ATTR_FOUND_ROWS' in /home/neuas/domains/anthonysalvador.info/public_html/webmail/program/lib/Roundcube/rcube_db_mysql.php on line 127
我联系了我的主人,他们拒绝了我。我联系了Roundcube,他们拒绝了我。有什么我可以忽略的吗?
这里是代码的PDO部分,包括错误的行:
102 protected function dsn_options($dsn)
103 {
104 $result = array();
105
106 if (!empty($dsn['key'])) {
107 $result[PDO::MYSQL_ATTR_KEY] = $dsn['key'];
108 }
109
110 if (!empty($dsn['cipher'])) {
111 $result[PDO::MYSQL_ATTR_CIPHER] = $dsn['cipher'];
112 }
113
114 if (!empty($dsn['cert'])) {
115 $result[PDO::MYSQL_ATTR_SSL_CERT] = $dsn['cert'];
116 }
117
118 if (!empty($dsn['capath'])) {
119 $result[PDO::MYSQL_ATTR_SSL_CAPATH] = $dsn['capath'];
120 }
121
122 if (!empty($dsn['ca'])) {
123 $result[PDO::MYSQL_ATTR_SSL_CA] = $dsn['ca'];
124 }
125
126 // Always return matching (not affected only) rows count
127 $result[PDO::MYSQL_ATTR_FOUND_ROWS] = true;
答案 0 :(得分:2)
花了几个小时追逐这个。我在Centos 6.5上使用PHP 5.3.3和MySQL 15.1(10.0.31 MariaDB)
对我来说,解决方法是获取mySQL-pdo文件。通过执行 yum install php-mysql-5.3.3-49.el6.x86_64 来解决。通过执行 yum whatprovides php pdo * .so
来选择该软件包我被带到了这条道路上: PHP 7 RC3: How to install missing MySQL PDO
这可能有点矫枉过正 - 如果是,请告诉我,但我也在/etc/php.ini中指定了扩展名(第925行) 延长=的/ usr / lib64下/ PHP /模块/ pdo_mysql.so
答案 1 :(得分:1)
我知道这是一个较老的主题,但我在寻找同一问题的解决方案时找到了它。这对我有用。我用文本编辑器打开db.inc.php并查看第25-28行,然后取消注释并编辑应用于我的安装的行。这删除了错误消息并完成安装。
//$rcmail_config['db_dsnw'] = 'mysql://roundcube:pass@localhost/roundcubemail';
// postgres example: 'pgsql://roundcube:pass@localhost/roundcubemail';
// Warning: for SQLite use absolute path in DSN:
// sqlite example: 'sqlite:////full/path/to/sqlite.db?mode=0646';
答案 2 :(得分:0)
我在安装一些php脚本时遇到了类似的问题。 解决方案是安装php56-pdo_mysql。 在BSD上,可以使用以下命令完成: pkg安装php56-pdo_mysql
希望这有帮助