Laravel操作session和cookie的方法是什么

其他教程   发布日期:2023年06月13日   浏览次数:490

本篇内容主要讲解“Laravel操作session和cookie的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel操作session和cookie的方法是什么”吧!

一:操作session

1:session配置

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

(1):配置session驱动

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

laravel自带的驱动

  • file - 将 Session 保存在 指定文件地址 中。

  • cookie - Session 保存在安全加密的 Cookie 中。

  • database - Session 保存在关系型数据库中。

  • memcached / redis - Sessions 保存在其中一个快速且基于缓存的存储系统中。

  • array - Sessions 保存在 PHP 数组中,不会被持久化。

(2):配置失效时间

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

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

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

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

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

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

  1. 'table' => 'sessions',

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

php artisan session:table

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

  1. /**
  2. * Run the migrations.
  3. *
  4. * @return void
  5. */
  6. public function up()
  7. {
  8. Schema::create('sessions', function (Blueprint $table) {
  9. $table->string('id')->unique();
  10. $table->unsignedBigInteger('user_id')->nullable();
  11. $table->string('ip_address', 45)->nullable();
  12. $table->text('user_agent')->nullable();
  13. $table->text('payload');
  14. $table->integer('last_activity');
  15. });
  16. }
  17. /**
  18. * Reverse the migrations.
  19. *
  20. * @return void
  21. */
  22. public function down()
  23. {
  24. Schema::dropIfExists('sessions');
  25. }

然后执行

php artisan migrate

这时候会在数据库中生成一个sessions表,这个表就是保存session数据的表

2:设置session

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

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

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

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

3:获取session

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

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

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

  1. $value = $request->session()->get('key', 'default');
  2. $value = $request->session()->get('key', function () {
  3. return 'default';
  4. });
  5. //确定 Session 中是否存在某个值,该值存在且不为 null,那么 has 方法会返回 true
  6. if ($request->session()->has('key')) {
  7. //
  8. }
  9. //确定 Session 中是否存在某个值,即使其值为 null,返回 true
  10. if ($request->session()->exists('key')) {
  11. //
  12. }

(2):使用全局辅助函数session获取

  1. $value = session('key');
  2. $value = session('key', 'default');
  3. $value = session()->get('key')
  4. $value = session()->get('key','default')
  5. session()->has('key');
  6. session()->exists('key');

4:删除session

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

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

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

  1. //删除指定session
  2. session()->forget('name');
  3. //清空所有session
  4. session()->flush();

5:重新生成 Session ID

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

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

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

  1. session()->regenerate();

二:操作cookie

1:设置cookie

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

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

  1. return
  2. esponse()->view('index',$data)->withCookie($cookie);

2:获取cookie

  1. Cookie::get('key');

3:删除cookie

  1. Cookie::forget('key');

以上就是Laravel操作session和cookie的方法是什么的详细内容,更多关于Laravel操作session和cookie的方法是什么的资料请关注九品源码其它相关文章!