thinkphp session

本文介绍了ThinkPHP中Session的基本操作方法及配置参数,包括启动、暂停、清除和销毁Session等功能。此外,还提供了如何设置私有Session空间以及数据库方式的Session操作示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ThinkPHP官方的说明文档

  1. start 启动session
  2. pause 暂停session
  3. clear 清除session
  4. destroy 销毁session
  5. get 获取session
  6. getLocal 获取私有session
  7. set 设置session
  8. setLocal 设置私有session
  9. name 获取或者设置session _name
  10. is_set 是否设置session
  11. is_setLocal 是否设置私有session
  12. id 获取或者设置session _id
  13. path 获取或者设置session _save_path
  14. setExpire 设置session 过期时间
  15. setCookieDomain 设置有效域名
  16. 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'); //转到注册页面
  }

 

 

页面模版:

<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>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值