欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ThinkPHP关于session的操作方法汇总

程序员文章站 2022-06-02 14:43:52
本文详细讲述了thinkphp关于session的各种操作方法,详情如下: thinkphp操作session官方的说明文档如下: start 启动session p...

本文详细讲述了thinkphp关于session的各种操作方法,详情如下:

thinkphp操作session官方的说明文档如下:

start 启动session
pause 暂停session
clear 清除session
destroy 销毁session
get 获取session值
getlocal 获取私有session值
set 设置session值
setlocal 设置私有session值
name 获取或者设置session_name
is_set 是否设置session值
is_setlocal 是否设置私有session值
id 获取或者设置session_id
path 获取或者设置session_save_path
setexpire 设置session过期时 间
setcookiedomain 设置有效域名
setcallback 设置session 对象反序列化时候的回调函数

最常用的操作方法示例代码如下:

// 检测session变量是否存在
session::is_set('name');
// 给session变 量赋值
session::set('name','value');
// 获取session变量
session::get('name');

和session相关的配置参数代码如下:

'session_name'=>'thinkid',        // 默认session_name
'session_path'=>'',            // 采用默认的session save path
'session_type'=>'file',            // 默认session类型 支持 db 和 file 
'session_expire'=>'300000',        // 默认session有效期
'session_table'=>'think_session',    // 数据库session方式表名
'session_callback'=>'',            // 反序列化对象的回调方法

其中session_name 参数需要注意,如果需要在不同的项目之间不共享传递session的值,请设置不同的值,否则请保留相同的默认值。
如果设置了相同的session_name的值,但是又希望创建基于项目的私有session空间,应该怎么处理呢?thinkphp还支持以项目为 session空间的私有session操作,以之前的常用操作为例,我们更改如下:

// 检测session变量是否存在(当前项目有效)
session::is_setlocal('name');
// 给session变 量赋值(当前项目有效)
session::setlocal('name','value');
// 获取session变量(当前 项目有效)
session::getlocal('name');

这样,和全局的session操作就不会冲突,可以用于一些特殊情况的需要。
thinkphp支持数据库方式的session操作,设置session_type的值为db就可以了,如果使用数据库方式,还要确保设置好session_table的值,并且导入下面的ddl到你的 数据库(以mysql为例子):

create table `think_session` (
`id` int(11) unsigned not null auto_increment,
`session_id` varchar(255) not null,
`session_expires` int(11) not null,
`session_data` blob,
primary key(`id`)
)

注意,db session方式的数据库连接会采用项目的数据库配置信息进行连接。除了数据库方式外,还可以增加其它方式的session保存机制,例如内存方式、 memcache方式等,我们只要增加相应的过滤器就行了,使用session_set_save_handler 方法,具体的方法定义参考think.util.filter下面的filtersessiondb.class.php 文件的实现。
 
制作了一个简单的登陆判断
登陆检测之后赋予session值,使session的值为非空即为假的false

$_session[c('user_auth_key')] = $loginfind['id'] ;

其中 [c('user_auth_key')]为thinkphp的内置方法和函数类。在未配置config.php文件时默认为空
把$loginfind['id'] 取出的帐号值赋予它,默认为关闭页面session就自动删除消失!
其它页面使用下面格式判断

if(!isset($_session[c('user_auth_key')])) { //isset 是检测变量是否赋值!
   $this->redirect('login','login'); //转到注册页面
}