关于laravel:laravel操作session和cookie

一:操作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数据表的文件

/**
     * 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');
    }

而后执行

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');

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理