|
一:操作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数据存入的数据库名使用database驱动时,在目录命令行执行- php artisan session:table
复制代码 这时候会在database/migrations目录下生成一个创建session数据表的文件- /**
- * Run the migrations.
- *
- * @return void
- */
- 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');
- });
- }
-
- /**
- * Reverse the migrations.
- *
- * @return void
- */
- public function down()
- {
- Schema::dropIfExists('sessions');
- }
复制代码 然后执行这时候会在数据库中生成一个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二:操作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
3:删除cookie
到此这篇关于Laravel操作session和cookie的教程详解的文章就介绍到这了,更多相关Laravel操作session cookie内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
来源:https://www.jb51.net/article/274850.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作! |
|