0

找到这个问题后,我让我的 Silex 会话至少分配了一个 ID,但我没有看到会话数据在不同的页面视图中保存:

require(__DIR__.'/vendor/autoload.php'); // Composer autoload

$app = new Silex\Application();
$app['debug'] = true;

$app['db'] = $app->share(function() { // Database connector as a service
    return new PDO('mysql:host=localhost;dbname=myawesome_db', 'user', 'paswd');
});

$app['session.db_options'] = array(
    'db_table'      => 'php_sessions',
    'db_id_col'     => 'session_id',
    'db_data_col'   => 'session_value',
    'db_time_col'   => 'session_time',
);

$app['session.storage.pdohandler'] = $app->share(function () use ($app) {
    return new Symfony\Component\HttpFoundation\Session\Storage\Handler\PdoSessionHandler(
        $app['db'],
        $app['session.db_options'],
        $app['session.storage.options']
    );
});
$app['session.storage'] = $app->share(function() use ($app) {
    return new Symfony\Component\HttpFoundation\Session\Storage\NativeSessionStorage(
        $app['session.storage.options'],
        $app['session.storage.pdohandler']
    );
});
$app->register(new Silex\Provider\SessionServiceProvider()); // Start session management
$app['session']->start();

$app->get('/session-set', function() use ($app) {
    $app['session']->set('foobar', 'test');
    $app['session']->save();
    $out = "User session is: ".$app['session']->getId()."<br />\n";
    $out .= "Session variable is: ".var_export($app['session']->get('foobar'), true)."<br />\n";
    return $out;
});
$app->get('/session-get', function() use ($app) {
    $out = "User session is: ".$app['session']->getId()."<br />\n";
    $out .= "Session variable is: ".var_export($app['session']->get('foobar'), true)."<br />\n";
    return $out;
});

$app->run(); // Off into the sunset

/session-set页面显示foobar会话变量的值,但该/session-get页面不显示。谁能帮我弄清楚为什么?

4

1 回答 1

0

我的解决方案原来是 PDO 数据库连接设置不正确(其中一个列名错误)。但是,默认情况下,PDO MySQL 连接在出错时不会抛出异常,它只是设置ErrorInfo()细节。一旦我为我的 PDO 连接打开异常抛出,我发现了错误并修复了它。我还向 Symfony 提交了一个补丁,以确保会话 PDO 对象启用了异常抛出,以避免其他人遇到这个问题。

于 2013-04-22T17:29:02.137 回答