Postgres的php pdo:“找不到驱动程序”

时间:2019-06-01 17:01:01

标签: php postgresql ubuntu pdo

我在用于Postgres的新Ubuntu 18.04服务器上安装了php,但是php存在问题。这是我的php 7.3安装步骤:

sudo apt install software-properties-common
sudo add-apt-repository ppa:ondrej/php]
sudo systemctl restart apache2

在安装PHP 7.3之后,我安装了pgsql。

sudo apt install php-pgsql
sudo service apache2 reload

接下来,我在/etc/php/7.3/apache2中编辑了php.ini文件,并从以下几行中删除了分号:

extension=pdo_pgsql
extension=pgsql

我保存了文件,然后sudo systemctl重新启动了apache2。

最后,我启用了模块:

sudo phpenmod -v 7.3 pgsql
sudo phpenmod -v 7.3 pdo_pgsql
sudo systemctl restart apache2

然后,我创建了一个脚本来使用pdo登录到我的Postgres数据库(登录凭据在这里被替换为占位符。)

<?php

$params = [
    'host' => '[IP Address]',
    'user' => '[username]',
    'pwd' => '[password]',
    'db' => '[dbname]'
];

$dsn = sprintf('pgsql:host=%s;dbname=%s;user=%s;password=%s',
    $params['host'],
    $params['db'],
    $params['user'],
    $params['pwd']);

try {
    $dsn = sprintf('pgsql:host=%s;dbname=%s;unix_socket=%s',
        $params['host'], $params['db'], $params['sock']);
    $opts = [PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION];
    $pdo = new PDO($dsn, $params['user'], $params['pwd'], $opts);
} catch (PDOException $e) {
    echo $e->getMessage();
} catch (Throwable $e) {
    echo $e->getMessage();
}

?>

但是Firefox开发者控制台回显:“找不到驱动程序。

一个线索是php 7.3在/ etc / apache2 / mods-available中,但不在/ etc / apache2 / mods-enabled中,这表明未启用它。但是,当我尝试phpenmod -v 7.3 php7.3.conf时,得到:警告:/etc/php/7.3/mods-available下的模块php7.3.conf ini文件不存在。

我对此做了很多研究,这些是要遵循的步骤。大部分研究是针对MySQL的,但这对PDO来说并不重要。

感谢您对为什么我收到“找不到驱动程序”消息的任何想法。

更新:

我创建了一个脚本来运行phpinfo():

<?php
ob_start();
phpinfo();
$info = ob_get_clean();
echo $info;
?>

但它仅返回html代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"><head>
<style type="text/css">
body {background-color: #fff; color: #222; font-family: sans-serif;}
pre {margin: 0; font-family: monospace;}
a:link {color: #009; text-decoration: none; background-color: #fff;}
a:hover {text-decoration: underline;}
table {border-collapse: collapse; border: 0; width: 934px; box-shadow: 1px 2px 3px #ccc;}
.center {text-align: center;}
.center table {margin: 1em auto; text-align: left;}
.center th {text-align: center !important;}
td, th {border: 1px solid #666; font-size: 75%; vertical-align: baseline; padding: 4px 5px;}
h1 {font-size: 150%;}
h2 {font-size: 125%;}
.p {text-align: left;}
.e {background-color: #ccf; width: 300px; font-weight: bold;}
.h {background-color: #99c; font-weight: bold;}
.v {background-color: #ddd; max-width: 300px; overflow-x: auto; word-wrap:  break-word;}
.v i {color: #999;}
img {float: right; bo…
jquery.min.js line 2 > eval:12:21
?

但这不是我所期望的。

1 个答案:

答案 0 :(得分:2)

从我们的谈话中看,问题是由安装了多个版本的PHP引起的,而Apache正在加载与预期的PHP 7.3不同的PHP(7.2)版本。

要解决此问题,请运行以下命令:

sudo a2dismod php7.2
sudo a2enmod php7.3

这将禁止Apache加载php7.2,而改为加载php7.3。


对于您的DSN(数据源名称),您当前的配置使用的是unix_socket,它似乎不是Postgresql DSN的有效选项。另外,缺少用于unix_socket参数的$params['socket']

有关更多详细信息,请参见:https://www.php.net/manual/en/ref.pdo-pgsql.connection.php

如果数据库服务器正在侦听默认端口(5432),则可以使用:

try {
    $dsn = vsprintf('pgsql:host=%s;port=%s;dbname=%s;user=%s;password=%s', [
        'host' => '[IP Address]',
        'port' => '5432',
        'dbname' => '[dbname]',
        'user' => '[username]',
        'password' => '[password]',
    ]);
    $pdo = new PDO($dsn);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch (PDOException $e) {
    echo $e->getMessage();
} catch (Throwable $e) {
    echo $e->getMessage();
}

DSN应该产生:https://3v4l.org/aFKAW

pgsql:host=[IP Address];port=5432;dbname=[dbname];user=[username];password=[password]