Php 如何用PDO连接Slim框架中的Postgresql数据库?

Php 如何用PDO连接Slim框架中的Postgresql数据库?,php,postgresql,slim,Php,Postgresql,Slim,我在slim框架中使用MYSQL数据库。它工作得很好。 但是要连接Postgresql,它也没有连接 下面是示例编码:(settings.php) 下面是代码:(dependencies.php) 我为MYSQL编写了示例代码,它工作得非常好。 Postgresql连接还缺少什么?检查是否启用了Postgresql扩展 扩展名=pdo_pgsql 你也可以从这个问题上寻求帮助 这里有一个bug: $dsn=newpdo(“pgsql:host=$host;port=$port;dbname=$d

我在slim框架中使用MYSQL数据库。它工作得很好。 但是要连接Postgresql,它也没有连接

下面是示例编码:(settings.php)

下面是代码:(dependencies.php)

我为MYSQL编写了示例代码,它工作得非常好。
Postgresql连接还缺少什么?

检查是否启用了Postgresql扩展

扩展名=pdo_pgsql

你也可以从这个问题上寻求帮助

这里有一个bug:

$dsn=newpdo(“pgsql:host=$host;port=$port;dbname=$dbname”);
返回新的PDO($dsn、$username、$password);
试试这个:

返回新的PDO(“pgsql:host=$host;port=$port;dbname=$dbname”,$username,$password);
    declare(strict_types=1);
    use App\Application\Settings\Settings;
    use App\Application\Settings\SettingsInterface;
    use DI\ContainerBuilder;
    use Monolog\Logger;
    
    return function (ContainerBuilder $containerBuilder) {
    
        $containerBuilder->addDefinitions([
            SettingsInterface::class => function () {
                return new Settings([
                    'displayErrorDetails' => true, // Should be set to false in production
                    'logError'            => true,
                    'logErrorDetails'     => true,
                    'logger' => [
                        'name' => 'slim-app',
                        'path' => isset($_ENV['docker']) ? 'php://stdout' : __DIR__ . '/../logs/app.log',
                        'level' => Logger::DEBUG,
                    ],
                        "db" =>
                               [
                                'driver'   => 'pgsql',
                                'host'     => 'localhost',
                                'port'     => '5433',
                                'database' => 'test_db',
                                'username' => 'postgres',
                                'password' => 'password',
                                'prefix'   => '',
                                'schema'   => 'public',
                            ]
    
                    ]);
            }
        ]);
};
<?php
declare(strict_types=1);

use App\Application\Settings\SettingsInterface;
use DI\ContainerBuilder;
use Monolog\Handler\StreamHandler;
use Monolog\Logger;
use Monolog\Processor\UidProcessor;
use Psr\Container\ContainerInterface;
use Psr\Log\LoggerInterface;

return function (ContainerBuilder $containerBuilder) {
    $containerBuilder->addDefinitions([
        LoggerInterface::class => function (ContainerInterface $c) {
            $settings = $c->get(SettingsInterface::class);

            $loggerSettings = $settings->get('logger');
            $logger = new Logger($loggerSettings['name']);

            $processor = new UidProcessor();
            $logger->pushProcessor($processor);

            $handler = new StreamHandler($loggerSettings['path'], $loggerSettings['level']);
            $logger->pushHandler($handler);

            return $logger;
        },
         PDO::class => function (ContainerInterface $c)
          {
 
            $settings = $c->get(SettingsInterface::class);
 
            $dbSettings = $settings->get("db");
 
            $host = $dbSettings['host'];
            $dbname = $dbSettings['database'];
            $username = $dbSettings['username'];
            $password = $dbSettings['password'];
            $port = $dbSettings['port'];
            $dsn = new PDO ("pgsql:host=$host;port=$port;dbname=$dbname");
           return new PDO($dsn, $username, $password);

        },

    ]);
};
<?php
declare(strict_types=1);

use App\Application\Actions\User\ListUsersAction;
use App\Application\Actions\User\ViewUserAction;
use Psr\Http\Message\ResponseInterface as Response;
use Psr\Http\Message\ServerRequestInterface as Request;
use Slim\App;
use Slim\Interfaces\RouteCollectorProxyInterface as Group;

return function (App $app) {
    $app->options('/{routes:.*}', function (Request $request, Response $response) {
        // CORS Pre-Flight OPTIONS Request Handler
        return $response;
    });

    $app->get('/', function (Request $request, Response $response) {
        $response->getBody()->write('Hello world!');
        return $response;
    });

    $app->group('/users', function (Group $group)
    {
        $group->get('', ListUsersAction::class);
        $group->get('/{id}', ViewUserAction::class);
    });

    $app->post('/db-select', function (Request $request, Response $response)
    {
        $db = $this->get(PDO::class);
        $sth = $db->prepare("SELECT * FROM login");
        $sth->execute();

        $data = $sth->fetchAll(PDO::FETCH_ASSOC);
        $payload = json_encode($data);
        $response->getBody()->write($payload);
        return $response->withHeader('Content-Type', 'application/json');
    });

};
{
    "statusCode": 500,
    "error": {
        "type": "SERVER_ERROR",
        "description": "SQLSTATE[08006] [7] fe_sendauth: no password supplied"
    }
}