thinkphp关于session的使用总结
ThinkPHP官方的说明文档
1start 启动session
2pause 暂停session
3clear 清除session
4destroy 销毁session
5get 获取session值
6getLocal 获取私有session值
7set 设置session值
8setLocal 设置私有session值
9name 获取或者设置session_name
10is_set 是否设置session值
11is_setLocal 是否设置私有session值
12id 获取或者设置session_id
13path 获取或者设置session_save_path
14setExpire 设置session过期时间
15setCookieDomain 设置有效域名
16setCallback 设置Session 对象反序列化时候的回调函数
最常用的操作方法示例:
代码:
17// 检测Session变量是否存在
18Session::is_set('name');
19
20// 给Session变量赋值
21
22Session::set('name','value');
23
24// 获取Session变量
25
26Session::get('name');
和Session相关的配置参数:
代码:
27'SESSION_NAME'=>'ThinkID', // 默认Session_name
28
29'SESSION_PA TH'=>'', & nbsp; // 采用默认的Session save path
30
31'SESSION_TYPE'=>'File', & nbsp; // 默认Session类型支
持DB 和File
32
33'SESSION_EXPIRE'=>'300000', & nbsp; // 默认Session有效期
34
35'SESSION_TABLE'=>'think_session', // 数据库Session方式表名
36
37'SESSION_CALLBACK'=>'', & nbsp; // 反序列化对象的回调方法
其中SESSION_NAME 参数需要注意,如果需要在不同的项目之间不共享传递Session的值,请设置不同的值,否则请保留相同的默认值。
如果设置了相同的SESSION_NAME的值,但是又希望创建基于项目的私有Session空间,应该怎么处理呢?ThinkPHP还支持以项目为Session空间的私有Session操作,以之前的常用操作为例,我们更改如下:
代码:
38// 检测Session变量是否存在(当前项目有效)
39Session::is_setLocal('name');
40
41// 给Session变量赋值(当前项目有效)
42
43Session::setLocal('name','value');
44
45// 获取Session变量(当前项目有效)
46
47Session::getLocal('name');
这样,和全局的Session操作就不会冲突,可以用于一些特殊情况的需要。
ThinkPHP支持数据库方式的Session操作,设置SESSION_TYPE的值为DB就可以了,如果使用数据库方式,还要确保设置好SESSION_TABLE的值,并且导入下面的DDL到你的数据库(以MySQL为例子):
代码:
48CREATE TABLE `think_session` (
49`
50id` int(11) unsigned NOT NULL auto_increment,
51`
52session_id` varchar(255) NOT NULL,
53`
54session_expires` int(11) NOT NULL,
55`
56session_data` blob,
57
58PRIMARY 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');//转到注册页面
}
本文档为【thinkphp关于session的使用总结】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑,
图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。