我正在尝试使用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
答案 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');