Heroku无法找到PDOServiceProvider

时间:2017-05-03 04:43:45

标签: php postgresql heroku pdo silex

所以我按照heroku提供的教程介绍了如何部署php应用程序https://devcenter.heroku.com/articles/getting-started-with-php#introduction

除非我设置数据库,否则一切正常。起初我尝试在线寻找不同的解决方案(即Dokku deployed Silex can't find PdoServiceProvider),但不是seens工作。

现在,我的代码看起来像这样:

<?php
    use Csanquer\Silex\PdoServiceProvider\Provider\PDOServiceProvider;
    //use Silex\Application;

    $dbopts = parse_url(getenv('DATABASE_URL'));
    $pdo = new PDOServiceProvider('pdo');
    //$app = new Application();
    $app->register($pdo,
        array(
            'pdo.server' => array(
                'driver'   => 'pgsql',
                'user' => $dbopts["user"],
                'password' => $dbopts["pass"],
                'host' => $dbopts["host"],
                'port' => $dbopts["port"],
                'dbname' => ltrim($dbopts["path"],'/')
            )
        )
    );
?>

我收到以下消息:

Uncaught Error: Class 'Csanquer\Silex\PdoServiceProvider\Provider\PDOServiceProvider' not found in /app/web/index.php:6

我该如何解决?

2 个答案:

答案 0 :(得分:1)

此答案已被删除。用户已被删除。

答案 1 :(得分:1)

我希望你之前使用过作曲家,如果没有,请告诉我。尝试使用您的作曲家安装Doctrine DBAL:

composer require "doctrine/dbal:~2.5"

安装Doctrine后,您可以使用以下代码行:

$config = new \Doctrine\DBAL\Configuration();

$connParams = array(
    'driver'   => #driver -> pdo_mysql,
    'dbname'   => #dbname,
    'host'     => #host -> localhost,
    'user'     => #user,
    'password' => #password,
    'charset'  => #charset -> utf8
);
$conn = \Doctrine\DBAL\DriverManager::getConnection($connParams, $config);

您现在可以使用以下内容:

$conn->query(#SomeSQL)
$conn->prepare(#SomeSQL)

或者你喜欢的方式:

$app->register(new Silex\Provider\DoctrineServiceProvider(), array(
    'db.options' => array(
        'driver'   => #driver -> pdo_mysql,
        'dbname'   => #dbname,
        'host'     => #host -> localhost,
        'user'     => #user,
        'password' => #password,
        'charset'  => #charset -> utf8
    ),
));

您现在可以使用以下内容:

$app['db']->query(#someSQL);

有关Doctrine DBAL的更多信息,请参阅此处或此处的页面。请告诉我这是否对您有所帮助! (通过将问题标记为已完成或评论新错误)。