## 概述
可以直接使用`think\facade\Session`类操作`Session`。
> 新版本不支持操作原生`$_SESSION`数组和所有`session_`开头的函数,只能通过`Session`类(或者助手函数)来操作。会话数据统一在当前请求结束的时候统一写入 所以不要在`session`写入操作之后执行`exit`等中断操作,否则会导致`Session`数据写入失败。
`6.0`的`Session`类可以很好的支持诸如`Swoole`/`Workerman`等环境。
## 开启Session
`Session`功能默认是没有开启的(API应用通常不需要使用`Session`),如果你需要使用`Seesion`,需要在全局的中间件定义文件中加上下面的中间件定义`'think\middleware\SessionInit'`:
~~~
return [
// 全局请求缓存
// \think\middleware\CheckRequestCache::class,
// 多语言加载
// \think\middleware\LoadLangPack::class,
// Session初始化
\think\middleware\SessionInit::class,
];
~~~
>[danger] 如果是多应用模式,并且你只是用于部分应用,那么也可以在应用中间件定义文件中单独开启。
## 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');
~~~
其中`set`和`delete`方法只能支持二级数组,其他方法支持任意级数组操作。
## 助手函数
系统也提供了助手函数`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()`方法)。
- 空白目录
- php语法结构
- 安装与更新
- 开启调试模式及代码跟踪器
- 架构
- 源码分析
- 应用初始化
- 请求流程
- 中间件源码分析
- 请求处理源码分析
- Request源码分析
- 模板编译流程
- 路由与请求流程
- 容器
- 获取目录位置
- 入口文件
- 多应用模式及URL访问
- 依赖注入与容器
- 容器属性及方法
- Container
- App
- facade
- 中间件(middleware)
- 系统服务
- extend 扩展类库
- 笔记
- 配置
- env配置定义及获取
- 配置文件的配置获取
- 单应用模式-(配置)文件目录结构(默认)
- 多应用模式(配置)文件目录结构(配置文件)
- 配置文件
- 应用配置:app.php
- 缓存配置: cache.php
- 数据库配置:database.php
- 路由和URL配置:route.php
- Cookie配置:cookie.php
- Session配置:session.php
- 命令行配置:console.php
- 多语言配置:lang.php
- 日志配置:log.php
- 页面Trace配置:trace.php
- 磁盘配置: filesystem.php
- 中间件配置:middleware.php
- 视图配置:view.php
- 改成用yaconf配置
- 事件
- 例子:省略事件类的demo
- 例子2:完整事件类
- 例子3:事件订阅,监听多个事件
- 解析
- 路由
- 路由定义
- 路由地址
- 变量规则
- MISS路由
- URL生成
- 闭包支持
- 路由参数
- 路由中间件
- 路由分组
- 资源路由
- 注解路由
- 路由绑定
- 域名路由
- 路由缓存
- 跨域路由
- 控制器
- 控制器定义
- 空控制器、空操作
- 空模块处理
- RESTFul资源控制器
- 控制器中间件
- 请求对象Request(url参数)
- 请求信息
- 获取输入变量($_POST、$_GET等)
- 请求类型的获取与伪装
- HTTP头信息
- 伪静态
- 参数绑定
- 请求缓存
- 响应对象Response
- 响应输出
- 响应参数
- 重定向
- 文件下载
- 错误页面的处理办法
- 应用公共文件common.php
- 模型
- 模型定义及常规属性
- 模型数据获取与模型赋值
- 查询
- 数据集
- 增加
- 修改
- 删除
- 条件
- 查询范围scope
- 获取器
- 修改器
- 搜索器
- 软删除
- 模型事件
- 关联预载入
- 模型关联
- 一对一关联
- 一对多关联
- 多对多关联
- 自动时间戳
- 事务
- 数据库
- 查询构造器
- 查询合集
- 子查询
- 聚合查询
- 时间查询
- 视图查询(比join简单)
- 获取查询参数
- 快捷方法
- 动态查询
- 条件查询
- 打印sql语句
- 增
- 删
- 改
- 查
- 链式操作
- 查询表达式
- 分页查询
- 原生查询
- JSON字段
- 链接数据库配置
- 分布式数据库
- 查询事件
- Db获取器
- 事务操作
- 存储过程
- Db数据集
- 数据库驱动
- 视图
- 模板
- 模板配置
- 模板位置
- 模板渲染
- 模板变量与赋值(assign)
- 模板输出替换
- url生成
- 模板详解
- 内置标签
- 三元运算
- 变量输出
- 函数输出
- Request请求参数
- 模板注释及原样输出
- 模板继承
- 模板布局
- 原生PHP
- 模板引擎
- 视图过滤
- 视图驱动
- 验证
- 验证进阶之最终版
- 错误和日志
- 异常处理
- 日志处理
- 调试
- 调试模式
- Trace调试
- SQL调试
- 变量调试
- 远程调试
- 杂项
- 缓存
- Session
- Cookie
- 多语言
- 上传
- 扩展说明
- N+1查询
- TP类库
- 扩展类库
- 数据库迁移工具
- Workerman
- think助手工具库
- 验证码
- Swoole
- request
- app
- Response
- View
- Validate
- Config
- 命令行
- 助手函数
- 升级指导(功能的添加与删除说明)
- siyucms
- 开始
- 添加页面流程
- 列表页加载流程
- 弹出框
- 基础控制器
- 基础模型
- 快速构建
- 表单form构建
- 表格table构建
- MakeBuilder
- 前端组件
- 日期组件
- layer 弹层组件
- Moment.js 日期处理插件
- siyucms模板布局
- 函数即其变量
- 前端页面
- $.operate.方法
- $.modal.方法:弹出层
- $.common.方法:通用方法
- 被cms重写的表格options
- 自定义模板
- 搜索框
- 自定义form表单
- 获取表单搜索参数并组装为url字符串