ThinkPHP官方的说明文档
-
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_NAME 参数需要注意,如果需要在不同的项目之间不共享传递Session的值,请设置不同的值,否则请保留相同的默认值。
如果设置了相同的SESSION_NAME的值,但是又希望创建基于项目的私有Session空间,应该怎么处理呢?ThinkPHP还支持以项目为Session空间的私有Session操作,以之前的常用操作为例,我们更改如下:
这样,和全局的Session操作就不会冲突,可以用于一些特殊情况的需要。
ThinkPHP支持数据库方式的Session操作,设置SESSION_TYPE的值为DB就可以了,如果使用数据库方式,还要确保设置好SESSION_TABLE的值,并且导入下面的DDL到你的数据库(以MySQL为例子):
注意,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'); //转到注册页面
}
页面模版:
<if condition="$_SESSION['login'] eq true">
欢迎您!<span class="cDRed"><a href="__APP__/userindex">{@UserIndex.username}</a></span>
<else/>
<a href="__APP__/login/tologin.shtml">登录</a> | <a href="__APP__/login/toreg.shtml">注册</a>
</if>