我在用于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
?
但这不是我所期望的。
答案 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]