Session 的配置文件存储在config/session.php中,配置参数有:
(1):配置session驱动
laravel自带的驱动
file – 将 Session 保存在 指定文件地址 中。cookie – Session 保存在安全加密的 Cookie 中。database – Session 保存在关系型数据库中。memcached / redis – Sessions 保存在其中一个快速且基于缓存的存储系统中。array – Sessions 保存在 PHP 数组中,不会被持久化。
(2):配置失效时间
(3):使用file驱动时session文件保存地址
(4):使用redis驱动时指定 Session 使用哪个 Redis 连接
(5):使用database驱动时将session数据存入的数据库名
使用database驱动时,在目录命令行执行
php artisan session:table
这时候会在database/migrations目录下生成一个创建session数据表的文件
{
Schema::create(‘sessions’, function (Blueprint $table) {
$table->string(‘id’)->unique();
$table->unsignedBigInteger(‘user_id’)->nullable();
$table->string(‘ip_address’, 45)->nullable();
$table->text(‘user_agent’)->nullable();
$table->text(‘payload’);
$table->integer(‘last_activity’);
});
}
public function down()
{
Schema::dropIfExists(‘sessions’);
}
然后执行
php artisan migrate
这时候会在数据库中生成一个sessions表,这个表就是保存session数据的表
(1):使用Request实例设置session
$request->session()->push(‘arr’,’item’);//session数组数据中追加数据
(2):使用全局辅助函数session设置
session()->push(‘arr’,’item’);//session数组数据中追加数据
(1):使用Request实例获取session
$value=$request->session()->get(‘key’);//获取指定session
获取指定session,不存在设置默认值
$value=$request->session()->get(‘key’, function () {
return ‘default’;
});
//确定 Session 中是否存在某个值,该值存在且不为 null,那么 has 方法会返回 true
if ($request->session()->has(‘key’)) {
//
}
//确定 Session 中是否存在某个值,即使其值为 null,返回 true
if ($request->session()->exists(‘key’)) {
//
}
(2):使用全局辅助函数session获取
$value=session(‘key’, ‘default’);
$value=session()->get(‘key’)
$value=session()->get(‘key’,’default’)
session()->has(‘key’);
session()->exists(‘key’);
(1):使用Request实例删除session
$value=$request->session()->pull(‘key’, ‘default’);
//删除指定session
$request->session()->forget(‘key’);
//删除所有session
$request->session()->flush();
(2):使用全局辅助函数session删除
session()->forget(‘name’);
//清空所有session
session()->flush();
(1):使用Request实例重新生成 Session ID
(2):使用全局辅助函数session重新生成 Session ID
Cookie::make(‘cookie_name’, ‘value’, 10);//设置cookie,cookie_name值为value,设置cookie时长10分钟
Cookie::forever(‘key’,’value’);//设置cookie,key值为value,永不过期
注意:如果使用Cookie::make()或Cookie::forever()方法设置cookie的话,渲染视图时不能直接使用:
到此这篇关于Laravel操作session和cookie的教程详解的文章就介绍到这了,更多相关Laravel操作session cookie内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!