ThinkPHP中session函数详解 |
在PHP中使用$_SESSION来操作session,而ThinkPHP提供了session的封装函数session() 。单单这一个函数就实现了session的增删改查的功能 。下面我们分别来看其应用与实现 。 该session()函数的定义是在Common/functions.php中定义 。 session配置 session($name='',$value='')函数有两个参数,$name为数组的时候是对session进行设置 。使用如下: $name = array( ‘name'=>'name', ‘path'=>'/tmp/', ‘expire'=>0 ); session($name); 这些是在开启session之前进行设置的 。在ThinkPHP中定义该函数的时候是先判断$name是否为数组,如果为数组的话就说明是在对session进行设置,然后进入相应的代码执行设置 。 其实现代码如下: if(is_array($name)) { // session初始化 在session_start 之前调用 if(isset($name['prefix'])) C('SESSION_PREFIX',$name['prefix']); if(C('VAR_SESSION_ID') && isset($_REQUEST[C('VAR_SESSION_ID')])){ session_id($_REQUEST[C('VAR_SESSION_ID')]); }elseif(isset($name['id'])) { session_id($name['id']); } if('common' != APP_MODE){ // 其它模式可能不支持 ini_set('session.auto_start', 0); } if(isset($name['name'])) session_name($name['name']); if(isset($name['path'])) session_save_path($name['path']); if(isset($name['domain'])) ini_set('session.cookie_domain', $name['domain']); if(isset($name['expire'])) { ini_set('session.gc_maxlifetime', $name['expire']); ini_set('session.cookie_lifetime', $name['expire']); } if(isset($name['use_trans_sid'])) ini_set('session.use_trans_sid',$name['use_trans_sid']?1:0); if(isset($name['use_cookies'])) ini_set('session.use_cookies', $name['use_cookies']?1:0); if(isset($name['cache_limiter'])) session_cache_limiter($name['cache_limiter']); if(isset($name['cache_expire'])) session_cache_expire($name['cache_expire']); if(isset($name['type'])) C('SESSION_TYPE',$name['type']); …… } 在ThinkPHP中,对于session的存储系统提供了mysql和memache两种数据库 。当然默认情况下是使用文件存储 。判断session存储方式的代码如下: if(C('SESSION_TYPE')) { // 读取session驱动 $type = C('SESSION_TYPE'); //系统调用mysql驱动程序 $class = strpos($type,'\\')? $type : 'Think\\Session\\Driver\\'. ucwords(strtolower($type)); $hander = new $class(); //实例化处理器 //注册处理器 session_set_save_handler( array(&$hander,"open"), array(&$hander,"close"), array(&$hander,"read"), array(&$hander,"write"), array(&$hander,"destroy"), array(&$hander,"gc") ); } 对于session存储系统的配置是通过配置选项SESSION_TYPE来设置的 。 SESSION_TYPE=>'Mysql' //将session存储在mysql数据库中 设置完成以后如果设置了session自动启动,那系统会自动开启session // 启动session if(C('SESSION_AUTO_START')) session_start(); 如果想关闭session自启动,对选项SESSION_AUTO_START设置如下: SESSION_AUTO_START => false 如果关闭了系统自启动,可以在项目的公共文件或者在控制器中通过手动调用session_start()来开启session 。或者使用函数session(),其开启方法如下: session(‘[start]'); 在ThinkPHP中其实现代码如下: if('[pause]'==$name){ // 暂停session session_write_close(); }elseif('[start]'==$name){ // 启动session session_start(); }elseif('[destroy]'==$name){ // 销毁session $_SESSION = array(); session_unset(); session_destroy(); }elseif('[regenerate]'==$name){ // 重新生成id session_regenerate_id(); } session赋值 session赋值比较简单,直接使用: session('name','onmpw'); 除此之外对于键值还可以是多层的中间使用‘.'连接 。 session(‘name1.name2','onmpw'); //等价于 $_SESSION[‘name1'][‘name2'] = ‘onmpw'; 在ThinkPHP中对于session赋值的实现代码如下: if(strpos($name,'.')){ list($name1,$name2) = explode('.',$name); if($prefix){ $_SESSION[$prefix][$name1][$name2] = $value; }else{ $_SESSION[$name1][$name2] = $value; } }else{ if($prefix){ $_SESSION[$prefix][$name] = $value; }else{ $_SESSION[$name] = $value; } } $prefix是通过选项SESSION_PREFIX来配置的 。 session取值 session取值相对来说也是比较简单的 。 首先是获取全部的session,使用方法如下 $values = session(); 此时得到的是一个数组 。在ThinkPHP中实现代码如下: if(''===$name){ // 获取全部的session return $prefix ? $_SESSION[$prefix] : $_SESSION; } 再就是取出单个值 $value1 = session(‘name'); //或者 $value2 = session(‘name1.name2'); 其实现代码如下: if(strpos($name,'.')){ list($name1,$name2) = explode('.',$name); return isset($_SESSION[$name1][$name2])?$_SESSION[$name1][$name2]:null; }else{ return isset($_SESSION[$name])?$_SESSION[$name]:null; } session删除 session的删除分为清空session,销毁session和删除单个session值 。 先说清空session 。清空session传参给$name的值为null session(null); //清空session 其实现代码如下: if(is_null($name)){ // 清空session if($prefix) { unset($_SESSION[$prefix]); }else{ $_SESSION = array(); } } 清空session只是将session对应的文件或者表中的数据清除,但是文件还是会存在的 。 销毁session session(‘[destroy]'); 其ThinkPHP中的实现代码如下: if('[destroy]'==$name){ // 销毁session $_SESSION = array(); session_unset(); session_destroy(); } 销毁session和清空session不同的是销毁session会将文件一并销毁 。 最后就是删除单个session值 。使用方式如下 session(‘name',null); 删除单个session值,将第二个参数$value的值设为null即可删除 。 if(is_null($value)){ // 删除session if(strpos($name,'.')){ list($name1,$name2) = explode('.',$name); if($prefix){ unset($_SESSION[$prefix][$name1][$name2]); }else{ unset($_SESSION[$name1][$name2]); } }else{ if($prefix){ unset($_SESSION[$prefix][$name]); }else{ unset($_SESSION[$name]); } } } 检查session 最后简单介绍对session的检查 。检查是指一个变量是否存在 。原生的PHP检查session变量是这样检查的 isset($_SESSION[‘name']); ThinkPHP封装之后使用session()函数是这样检查 session(‘?name'); //判断一个session是否已经设置 其代码实现也是利用了原生的检查的方式 $name = substr($name,1); if(strpos($name,'.')){ // 支持数组 list($name1,$name2) = explode('.',$name); return $prefix?isset($_SESSION[$prefix][$name1][$name2]):isset($_SESSION[$name1][$name2]); }else{ return $prefix?isset($_SESSION[$prefix][$name]):isset($_SESSION[$name]); } 以上几乎是对session()函数各个功能的使用介绍,以及ThinkPHP是如何实现的 。希望本文的内容对大家在使用ThinkPHP过程中起到一些帮助作用 。 |