Laravel不在数据库中存储其他会话属性

时间:2019-01-04 12:04:17

标签: php laravel sqlite session laravel-session

我正在尝试使用laravel会话逻辑将特定属性存储在用户的会话表中。

会话表迁移

Schema::create('sessions', function (Blueprint $table) {
    $table->string('id')->unique();
    $table->unsignedInteger('user_id')->nullable();
    $table->string('ip_address', 45)->nullable();
    $table->text('user_agent')->nullable();
    $table->text('payload');
    $table->text('activeEvent')->nullable();
    $table->integer('last_activity');
});

ENV配置

APP_NAME=Laravel
APP_ENV=local
APP_KEY={KEY}
APP_DEBUG=true
APP_URL=http://localhost

LOG_CHANNEL=stack

DB_CONNECTION=sqlite

BROADCAST_DRIVER=log
CACHE_DRIVER=file
QUEUE_CONNECTION=sync
SESSION_DRIVER=database
SESSION_LIFETIME=120

代码

Route::post('/set-event', function(Request $request){
    Session::put('activeEvent', $request->get('event'));
    Session::save();
    return redirect()->route('home');
});

会话表中的每个属性都会更新,但“ activeEvent”属性始终为空。

“ $ request-> get('event')”返回所选事件的整数。通过将activeEvent的数据类型设置为整数已经尝试过。

还尝试了以下代码片段:

$request->session()->push
$request->session()->put
$request->session()->keep

没有任何效果。如何将activeEvent属性存储在数据库中?还是不可能?

我正在使用PHP7.2 / Laravel 5.7 / SQLITE

1 个答案:

答案 0 :(得分:0)

对于Laravel Session的数据库驱动程序的工作方式,您似乎有一个错误的想法。 sessions表的每一行代表一个用户的所有会话数据。当您执行Session::put('activeEvent', $value);时,它将此'activeEvent' => $value键/值对存储在payload列中。

您无需更改此表即可为要存储的每个键提供列-数据库会话驱动程序将序列化所有键/值对并将其放入payload列中。

因此,在您的情况下,将sessions表迁移还原为您最初使用php artisan session:table命令生成表时的迁移方式。并照常使用Session:put()进行存储,get()进行以下读取:

Route::post('/set-event', function(Request $request){
    Session::put('activeEvent', $request->get('event'));

    return redirect()->route('home');
});

...

// Somewhere when you need to retrieve the value
$activeEvent = Session::get('activeEvent');