PHP开发笔记's Archiver

fangzhen 发表于 2009-11-25 09:12

thinkphp Session类库解析和使用系列

[ 概述 ]
ThinkPHP对Session操作进行了封装,并且无需引入就可以使用,Session的启动会在应用初始化的时候自动执行,所以无需手动使用Session::start() 来启动Session。
使用Session类操作和普通方式调用$_SESSION来操作并没有本质不同,只是Session类很多参数可以根据项目配置来灵活设置。

[ 方法 ]
Session类封装了很多的静态操作方法,常用方法包括包括:
[list=1][*]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 对象反序列化时候的回调函数[/list]

[ 示例 ]
最常用的操作方法示例:
[list=1][*]// 检测Session变量是否存在[*]Session::is_set('name');[*]// 给Session变量赋值[*]Session::set('name','value');[*]// 获取Session变量[*]Session::get('name');[/list]

和Session相关的配置参数:
[list=1][*]        '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'=>'',                        // 反序列化对象的回调方法[/list]

其中SESSION_NAME 参数需要注意,如果需要在不同的项目之间不共享传递Session的值,请设置不同的值,否则请保留相同的默认值。
如果设置了相同的SESSION_NAME的值,但是又希望创建基于项目的私有Session空间,应该怎么处理呢?ThinkPHP还支持以项目为Session空间的私有Session操作,以之前的常用操作为例,我们更改如下:
[list=1][*]// 检测Session变量是否存在(当前项目有效)[*]Session::is_setLocal('name');[*]// 给Session变量赋值(当前项目有效)[*]Session::setLocal('name','value');[*]// 获取Session变量(当前项目有效)[*]Session::getLocal('name');[/list]

这样,和全局的Session操作就不会冲突,可以用于一些特殊情况的需要。

ThinkPHP支持数据库方式的Session操作,设置SESSION_TYPE的值为DB就可以了,如果使用数据库方式,还要确保设置好SESSION_TABLE的值,并且导入下面的DDL到你的数据库(以MySQL为例子):
[list=1][*]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`)[*])[/list]

注意,Db Session方式的数据库连接会采用项目的数据库配置信息进行连接。除了数据库方式外,还可以增加其它方式的Session保存机制,例如内存方式、Memcache方式等,我们只要增加相应的过滤器就行了,使用session_set_save_handler方法,具体的方法定义参考Think.Util.Filter下面的FilterSessionDb.class.php 文件的实现。

页: [1]

Powered by Discuz! Archiver 6.1.0  © 2001-2007 Comsenz Inc.