ThinkPHP关于session的操作的解决办法
这篇文章主要为大家详细介绍了ThinkPHP关于session的操作的简单示例,具有一定的参考价值,可以用来参考一下。
感兴趣的小伙伴,下面一起跟随php教程的小玲来看看吧!
ThinkPHP操作session官方的说明文档如下:
start 启动sessionpause 暂停sessionclear 清除sessiondestroy 销毁sessionget 获取session值getLocal 获取私有session值set 设置session值setLocal 设置私有session值name 获取或者设置session_nameis_set 是否设置session值is_setLocal 是否设置私有session值id 获取或者设置session_idpath 获取或者设置session_save_pathsetExpire 设置session过期时 间setCookieDomain 设置有效域名setCallback 设置Session 对象反序列化时候的回调函数
最常用的操作方法示例代码如下:
代码如下:
1 2 3 4 5 6 7 8 9 | <code> // 检测Session变量是否存在 Session::is_set( 'name' ); // 给Session变 量赋值 Session::set( 'name' , 'value' ); // 获取Session变量 Session::get( 'name' ); </code> |
ThinkPHP关于session的操作方法汇总
和Session相关的配置参数代码如下:
代码如下:
1 2 3 4 5 6 7 8 9 | <code> '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' => '' , // 反序列化对象的回调方法 </code> |
ThinkPHP关于session的操作方法汇总
其中SESSION_NAME 参数需要注意,如果需要在不同的项目之间不共享传递Session的值,请设置不同的值,否则请保留相同的默认值。如果设置了相同的SESSION_NAME的值,但是又希望创建基于项目的私有Session空间,应该怎么处理呢?ThinkPHP还支持以项目为 Session空间的私有Session操作,以之前的常用操作为例,我们更改如下:
代码如下:
1 2 3 4 5 6 7 8 9 | <code> // 检测Session变量是否存在(当前项目有效) Session::is_setLocal( 'name' ); // 给Session变 量赋值(当前项目有效) Session::setLocal( 'name' , 'value' ); // 获取Session变量(当前 项目有效) Session::getLocal( 'name' ); </code> |
ThinkPHP关于session的操作方法汇总
这样,和全局的Session操作就不会冲突,可以用于一些特殊情况的需要。ThinkPHP支持数据库方式的Session操作,设置SESSION_TYPE的值为DB就可以了,如果使用数据库方式,还要确保设置好SESSION_TABLE的值,并且导入下面的DDL到你的 数据库(以MySQL为例子):
代码如下:
1 2 3 4 5 6 7 8 9 10 | <code> 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`) ) </code> |
ThinkPHP关于session的操作方法汇总
注意,Db Session方式的数据库连接会采用项目的数据库配置信息进行连接。除了数据库方式外,还可以增加其它方式的Session保存机制,例如内存方式、 Memcache方式等,我们只要增加相应的过滤器就行了,使用session_set_save_handler 方法,具体的方法定义参考Think.Util.Filter下面的FilterSessionDb.class.php 文件的实现。制作了一个简单的登陆判断登陆检测之后赋予Session值,使Session的值为非空即为假的false
代码如下:
1 2 3 4 | <code> $_SESSION [C( 'USER_AUTH_KEY' )] = $logInFind [ 'id' ] ; </code> |
ThinkPHP关于session的操作方法汇总
其中 [C('USER_AUTH_KEY')]为ThinkPHP的内置方法和函数类。在未配置config.php文件时默认为空把$logInFind['id'] 取出的帐号值赋予它,默认为关闭页面Session就自动删除消失!其它页面使用下面格式判断
代码如下:
1 2 3 4 5 6 | <code> if (!isset( $_SESSION [C( 'USER_AUTH_KEY' )])) { //isset 是检测变量是否赋值! $this ->redirect( 'Login' , 'Login' ); //转到注册页面 } </code> |
ThinkPHP关于session的操作方法汇总
注:关于ThinkPHP关于session的操作的简单示例的内容就先介绍到这里,更多相关文章的可以留意