如何在Illuminate库中创建数据库连接作为Illuminate \ Database \ ConnectionInterface实例的实例?

时间:2016-05-01 11:30:48

标签: php laravel illuminate-container

我正在开发一个苗条框架中的restful应用程序。我正在使用一个使用照明数据库的会话管理器。它需要我使用Laravel的照明实例创建数据库连接。但是我收到了一个错误。这是我的代码:

<?php
require 'lib/vendor/PHPMailer/PHPMailerAutoload.php';
require 'lib/init.php';
require 'lib/Slim/Slim.php';

date_default_timezone_set('UTC');

use lib\Slim\Middleware\SessionCookie;

\Slim\Slim::registerAutoloader();

$app = new \Slim\Slim([
    // cookie encryption (strongly recommend)
    'cookies.encrypt' => true,
    'cookies.secret_key' => 'put your secret key',
    // session config
    'sessions.driver' => 'database', // or database
    //'sessions.files' => __DIR__ . '/../sessions', // require mkdir
    'sessions.table' => 'sessions', // require create table
]);

$manager = new \Slim\Middleware\SessionManager($app);
$session = new \Slim\Middleware\Session($manager);

$manager->setDbConnection(mysql_connect('localhost', 'username', 'password', 'database'));

$app->add($session); 

$app->run();

这是我得到的错误:

  

参数1传递给   Illuminate \ Session \ DatabaseSessionHandler :: __ construct()必须是   Illuminate \ Database \ ConnectionInterface的实例,给定的资源

如果有人能指出我正确的方向,我会非常感激。

提前致谢。

1 个答案:

答案 0 :(得分:2)

您可以在此处查看\ Illuminate \ Database的源代码:
https://github.com/illuminate/database

Taylor在提供独立使用此模块和创建数据库连接的文档方面做得非常出色。使用Illuminate \ Database \ Capsule \ Manager作为Capsule;

$capsule = new Capsule;

$capsule->addConnection([
    'driver'    => 'mysql',
    'host'      => 'localhost',
    'database'  => 'database',
    'username'  => 'root',
    'password'  => 'password',
    'charset'   => 'utf8',
    'collation' => 'utf8_unicode_ci',
    'prefix'    => '',
]);