广告
返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >Laravel操作session和cookie的教程详解
  • 753
分享到

Laravel操作session和cookie的教程详解

摘要

目录一:操作session1:session配置2:设置session3:获取session4:删除session5:重新生成 Session ID二:操作cookie1:设置coo

一:操作session

1:session配置

Session 的配置文件存储在config/session.PHP中,配置参数有:

(1):配置session驱动

'driver' => env('SESSION_DRIVER', 'file'),//#这里表示先读取.env文件的SESSION_DRIVER参数值,如果没有使用file驱动

laravel自带的驱动

  • file - 将 Session 保存在 指定文件地址 中。
  • cookie - Session 保存在安全加密的 Cookie 中。
  • database - Session 保存在关系型数据库中。
  • memcached / Redis - Sessions 保存在其中一个快速且基于缓存的存储系统中。
  • array - Sessions 保存在 php 数组中,不会被持久化。

(2):配置失效时间

'lifetime' => env('SESSION_LIFETIME', 120),

(3):使用file驱动时session文件保存地址

'files' => storage_path('framework/sessions'),

(4):使用redis驱动时指定 Session 使用哪个 Redis 连接

'connection' => null,//不修改使用默认的redis

(5):使用database驱动时将session数据存入的数据库名

'table' => 'sessions',

使用database驱动时,在目录命令行执行

php artisan session:table

这时候会在database/migrations目录下生成一个创建session数据表的文件


    public function up()
    {
        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数据的表

2:设置session

(1):使用Request实例设置session

$request->session()->put('key', 'value');//设置session
$request->session()->push('arr','item');//session数组数据中追加数据

(2):使用全局辅助函数session设置

session(['key' => 'value']);//设置session
session()->push('arr','item');//session数组数据中追加数据

3:获取session

(1):使用Request实例获取session

$data = $request->session()->all();//获取所有session
$value = $request->session()->get('key');//获取指定session

获取指定session,不存在设置默认值

$value = $request->session()->get('key', 'default');
$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');
$value = session('key', 'default');
$value = session()->get('key')
$value = session()->get('key','default')
session()->has('key');
session()->exists('key');

4:删除session

(1):使用Request实例删除session

//获取到session数据然后删除session
$value = $request->session()->pull('key', 'default');
//删除指定session
$request->session()->forget('key');
//删除所有session
$request->session()->flush();

(2):使用全局辅助函数session删除

//删除指定session
session()->forget('name');
//清空所有session
session()->flush();

5:重新生成 Session ID

(1):使用Request实例重新生成 Session ID

$request->session()->regenerate();

(2):使用全局辅助函数session重新生成 Session ID

session()->regenerate();

二:操作cookie

1:设置cookie

Cookie::queue('test', 'testValue', 10);//设置cookie,test值为testValue,设置cookie时长10分钟
Cookie::make('cookie_name', 'value', 10);//设置cookie,cookie_name值为value,设置cookie时长10分钟
Cookie::forever('key','value');//设置cookie,key值为value,永不过期

注意:如果使用Cookie::make()或Cookie::forever()方法设置cookie的话,渲染视图时不能直接使用:

return \response()->view('index',$data)->withCookie($cookie);

2:获取cookie

Cookie::get('key');

3:删除cookie

Cookie::forget('key');

到此这篇关于Laravel操作session和cookie的教程详解的文章就介绍到这了,更多相关Laravel操作session cookie内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Laravel操作session和cookie的教程详解

本文链接: https://www.lsjlt.com/news/195408.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作