Laravel session
数据库
使用 database
作为 Session 驱动时,你需要创建一张包含 Session 各项数据的表。以下例子是使用 Schema
建表:
Schema::create('sessions', function ($table) {
$table->string('id')->unique();
$table->integer('user_id')->nullable();
$table->string('ip_address', 45)->nullable();
$table->text('user_agent')->nullable();
$table->text('payload');
$table->integer('last_activity');
});
Redis
Laravel 在使用 Redis 作为 Session 驱动,需要通过 Composer 安装 predis/predis
扩展包.
获取数据
Laravel 中处理 Session 数据有两种主要方法:全局辅助函数 session
和通过一个 Request
实例
public function show(Request $request, $id)
{
$value = $request->session()->get('key');
//
}
$value = $request->session()->get('key', 'default');
$value = $request->session()->get('key', function () {
return 'default';
});
/ 获取 Session 中的一条数据...
$value = session('key');
// 指定一个默认值...
$value = session('key', 'default');
// 在 Session 中存储一条数据...
session(['key' => 'value']);
获取所有 Session 数据
$data = $request->session()->all();
判断 Session 中是否存在某个值
$request->session()->has('users')
存储数据
// 通过 HTTP 请求实例...
$request->session()->put('key', 'value');
// 通过全局辅助函数
session(['key' => 'value']);
在 Session 数组中保存数据
$request->session()->push('user.teams', 'developers');
检索 & 删除
$value = $request->session()->pull('key', 'default');
删除数据
$request->session()->forget('key');
$request->session()->flush();