6Session
未知
2021-07-04 11:44:44
0

概述

可以直接使用think\facade\Session类操作Session

新版本不支持操作原生$_SESSION数组和所有session_开头的函数,只能通过Session类(或者助手函数)来操作。会话数据统一在当前请求结束的时候统一写入 所以不要在session写入操作之后执行exit等中断操作,否则会导致Session数据写入失败。

6.0Session类可以很好的支持诸如Swoole/Workerman等环境。

开启Session

Session功能默认是没有开启的(API应用通常不需要使用Session),如果你需要使用Seesion,需要在全局的中间件定义文件中加上下面的中间件定义:

'think\middleware\SessionInit'
复制

如果是多应用模式,并且你只是用于部分应用,那么也可以在应用中间件定义文件中单独开启。

Session初始化

系统会自动按照session.php配置的参数自动初始化Session

默认支持的session设置参数包括:

参数 描述
type session类型(File或者Cache
store 当type设置为cache类型的时候指定存储标识
expire session过期时间(秒)必须大于0
var_session_id 请求session_id变量名
name session_name
prefix session前缀
serialize 序列化方法

无需任何操作就可以直接调用Session类的相关方法,例如:

Session::set('name', 'thinkphp');
Session::get('name');
复制

会话数据保存(请求结束)的时候会自动序列化,并在读取的时候自动反序列化,默认使用serialize/unserialize进行序列化操作,你可以自定义序列化机制。

例如在配置文件中设置为使用JSON序列化:

'serialize'    =>    ['json_encode', 'json_decode'],
复制

尽量避免把对象保存到Session会话

基础用法

赋值

Session::set('name', 'thinkphp');
复制

判断是否存在

Session::has('name');
复制

取值

// 如果值不存在,返回null
Session::get('name');
// 如果值不存在,返回空字符串
Session::get('name', '');
// 获取全部数据
Session::all();
复制

删除

Session::delete('name');
复制

取值并删除

// 取值并删除
Session::pull('name');
复制

如果name的值不存在,返回Null

清空

Session::clear();
复制

闪存数据,下次请求之前有效

// 设置session 并且在下一次请求之前有效
Session::flash('name','value');
复制

提前清除当前请求有效的数据

// 清除当前请求有效的session
Session::flush();
复制

注意,Session写入数据的操作会在请求结束的时候统一进行本地化存储,所以不要在写入Session数据之后使用exit等中断操作,可能会导致Session没有正常写入。

多级数组

支持session的多级数组操作,例如:

// 赋值
Session::set('name.item','thinkphp');
// 判断是否赋值
Session::has('name.item');
// 取值
Session::get('name.item');
// 删除
Session::delete('name.item');
复制

其中setdelete方法只能支持二级数组,其他方法支持任意级数组操作。

助手函数

系统也提供了助手函数session完成相同的功能,例如:

// 赋值
session('name', 'thinkphp');
// 判断是否赋值
session('?name');
// 取值
session('name');
// 删除
session('name', null);
// 清除session
session(null);
复制

Request对象中读取Session

可以在Request对象中读取Session数据

public function index(Request $request) {
    // 读取某个session数据
    $request->session('user.name', '');
    // 获取全部session数据
    $request->session();
}
复制

Request类中不支持Session写入操作。

应用独立会话

多应用情况下默认Session是跨应用的,也就是说多应用之间是共享会话数据的,如果不希望共享会话数据,可以给每个应用设置不同的前缀prefix

如果是File类型的话,默认的session会话数据保存在runtime/session目录下面,你可以设置path改变存储路径。

Session驱动

默认的Session驱动采用文件缓存方式记录,并且支持如下配置

参数 描述
path session保存路径
data_compress 是否压缩数据
gc_divisor GC回收概率
gc_probability GC回收概率

除了文件类型之外,还可以支持直接使用缓存作为Session类型,例如:

return [
    'type'       => 'cache',
    'store'      => 'redis',
    'prefix'     => 'think',
]
复制

表示使用redis作为session类型。

要以上的配置生效,请确保缓存配置文件cache.php中的stores中已经添加了redis缓存配置,例如:

return [
    'default'    =>    'file',
    'stores'    =>    [
        // 文件缓存
        'file'   =>  [
            // 驱动方式
            'type'   => 'file',
            // 设置不同的缓存保存目录
            'path'   => '../runtime/file/',
        ],  
        // redis缓存
        'redis'   =>  [
            // 驱动方式
            'type'   => 'redis',
            // 服务器地址
            'host'       => '127.0.0.1',
        ],  
    ],
];
复制

自定义驱动

如果需要自定义Session驱动,你的驱动类必须实现think\contract\SessionHandlerInterface接口,包含了三个方法。

interface SessionHandlerInterface
{
    public function read(string $sessionId): string;
    public function delete(string $sessionId): bool;
    public function write(string $sessionId, string $data): bool;
}
复制

read方法是在调用Session::start()的时候执行,并且只会执行一次。
write方法是在本地化会话数据的时候执行(调用Session::save()方法),系统会在每次请求结束的时候自动执行。
delete方法是在销毁会话的时候执行(调用Session::destroy()方法)。

上一篇:6缓存

下一篇:6Cookie

相关内容

如何使用MySQL变量进行...
本文详细介绍了MySQL中用户定义变量、系统变量和局部变量的使用方...
2024-11-20 18:46:45
拼多多购物优惠券,优惠力度...
拼多多购物优惠券种类多,优惠力度大,可省下不少钱。可通过平台活动、...
2024-11-20 12:00:43
PHP与SQLSRV连接数...
PHP与SQLSRV连接SQL Server数据库教程,介绍安装配...
2024-11-20 11:23:44
PHP与SQLSRV连接M...
本文介绍了使用PHP和SQLSRV扩展连接MySQL数据库的实例,...
2024-11-20 11:00:46
PHP SQLSRV数据库...
本文介绍了使用PHP SQLSRV扩展进行数据库操作的示例,包括连...
2024-11-20 10:23:47
PHP中SQLSRV扩展的...
PHP中SQLSRV扩展使用技巧:通过安装配置、连接数据库、执行S...
2024-11-20 08:46:43

热门资讯

tp6开发规范 命名规范 请理解并尽量遵循以下命名规范,可以减少在开发过程中出现不必要的错误。 ThinkPHP6....
6高级查询 快捷查询 快捷查询方式是 一种多字段相同查询条件 的简化写法,可以进一步简化查询条件的写法,在多个字...
tp6多应用提示控制器不存在:... 第一个情况是没有使用composer安装扩展。 如果要使用多应用模式, 你需要win+r,cmd指针...
6配置 配置目录 单应用模式 对于单应用模式来说,配置文件和目录很简单,根目录下的 config 目录下面就...
6异常处理 和PHP默认的异常处理不同,ThinkPHP抛出的不是单纯的错误信息,而是一个人性化的错误页面。 异...
6swoole 本篇内容主要讲述了最新的 think-swoole 扩展的使用。目前仅支持Linux环境或者MacO...
6助手函数 助手函数 系统为一些常用的操作方法封装了助手函数,便于使用,包含如下: 助手函数 描述 abort ...
6查询表达式 查询表达式 查询表达式支持大部分的SQL查询语法,也是 ThinkPHP 查询语言的精髓,查询表达式...
6路由参数 路由参数 路由分组及规则定义支持指定路由参数,这些参数主要完成路由匹配检测以及后续行为。 路由参数可...
6查询 模型查询和数据库查询方法的区别主要在于,模型中的查询的数据在获取的时候会经过获取器的处理,以及更加对...