zoukankan      html  css  js  c++  java
  • PHP实现session对象封装

    <?php
    class Session
    {
    	private $db;				// 设置数据库变量
    	private $expiry = 3600;		// 设置Session失效时间	
    	
    	public function Session()
    	{
    		session_set_save_handler(array(& $this,'_session_open'),
    								array(& $this,'_session_close'),
    								array(& $this,'_session_read'),
    								array(& $this,'_session_write'),
    								array(& $this,'_session_destroy'),
    								array(& $this,'_session_gc')
    		);	
    	}	
    	
    	public function _session_open($save_path,$session_name)
    	{
    		$this->db = mysql_connect('localhost','root','123456') or die ("数据库连接失败!");
    		mysql_select_db("db_database11",$this->db);
    		return(true);
    	}
    	
    	public function _session_close()
    	{
    		mysql_close($this->db);
    		return(true);
    	}
    	
    	public function _session_read($key)
    	{
    		$time = time();							// 设定当前时间
    		$sql = "select session_data from tb_session where session_key = '$key' and session_time > $time";
    		$result = mysql_query($sql,$this->db);
    		$row = mysql_fetch_array($result);
    		if ($row)
    		{
    			return($row['session_data']);			// 返回Session名称及内容
    		}else
    		{
    			return(false);
    		}
    	}
    	
    	public function _session_write($key,$data)
    	{
    		$lapse_time = time() + $this->time;					// 得到Unix时间戳
    		$sql = "select session_data from tb_session where session_key = '$key' and session_time > $lapse_time";
    		$result = mysql_query($sql,$this->db);
    		if (mysql_num_rows($result) == 0 )				// 没有结果
    		{
    			$sql = "insert into tb_session values('$key','$data',$lapse_time)";		// 插入数据库sql语句
    			$result = mysql_query($sql,$this->db);
    		}else
    		{
    			$sql = "update tb_session set session_key = '$key',session_data = '$data',session_time = $lapse_time where session_key = '$key'";												// 修改数据库sql语句
    			$result = mysql_query($sql,$this->db);
    		}
    		return($result);
    	}
    	
    	public function _session_destroy($key)
    	{
    		$sql = "delete from tb_session where session_key = '$key'";					// 删除数据库sql语句
    		$result = mysql_query($sql,$this->db);
    		return($result);
    	}
    	
    	public function _session_gc($expiry_time)
    	{
    		$expiry_time = time();									// 将参数$expiry_time赋值为当前时间戳
    		$sql = "delete from tb_session where expiry_time < $expiry_time";	// 删除数据库sql语句
    		$result = mysql_query($sql,$this->db);
    		return($result);
    	}
    }
    $_session_new = new Session();
    session_start();
    
    $_SESSION['SID'] = true;
    ?>
    

      

    这里令人费解的是,$this本来就是引用类型,按理说PHP的引用操作符&只是针对基本变量(非引用类型)所采取的一种补救措施,这里针对$$this进行引用,又是为何?

  • 相关阅读:
    ObjectiveC初步研究 实现文件(Implementation File)
    SQL技巧(二) CTE(公用表达式)初步接触
    ObjectiveC编程基础
    Linux编程 使用C在mysql中插入数据
    办理户口
    修改kernel内核HZ频率没有效果问题
    如何从湖北省人才市场将户口迁移出来?
    查看 各种寄存器值的 内核模块 C语言
    SDRAM AND SRAM
    linux2.6.26内核中ARM中断实现详解(转)
  • 原文地址:https://www.cnblogs.com/ioveNature/p/6918400.html
Copyright © 2011-2022 走看看