用session_set_save_handler函数实现将session保存在数据库中后session不能跨页面了

<?php
/*============================文件说明========================================
@filename:     session.class.php
@description:  数据库保存在线用户session,实现在线用户功能!
@notice:       session过期时间一个小时,因为我们的站点是使用cookie(有效时间是1小时)登录。

               因此我们只记录用户登录的时间,而不是刷新一次更新一次

               删除数据库中session记录的动作发生在用户超时后执行这个文件或正常退出(session_destory)

@database:     database:sessions  field:sessionid(char32),uid(int10),last_visit(int10)

=============================================================================*/
class session { 
    private $db; 
	private $lasttime=3600;//超时时间:一个小时

    function session(&$db) { 
        $this->db = &$db;
        session_module_name(‘user‘); //session文件保存方式,这个是必须的!除非在Php.ini文件中设置了
        session_set_save_handler( 
            array(&$this, ‘open‘), //在运行session_start()时执行

            array(&$this, ‘close‘), //在脚本执行完成或调用session_write_close() 或 session_destroy()时被执行,即在所有session操作完后被执行

            array(&$this, ‘read‘), //在运行session_start()时执行,因为在session_start时,会去read当前session数据
            array(&$this, ‘write‘), //此方法在脚本结束和使用session_write_close()强制提交SESSION数据时执行

            array(&$this, ‘destroy‘), //在运行session_destroy()时执行

            array(&$this, ‘gc‘) //执行概率由session.gc_probability 和 session.gc_divisor的值决定,时机是在open,read之后,session_start会相继执行open,read和gc
        ); 
        session_start(); //这也是必须的,打开session,必须在session_set_save_handler后面执行
    } 
  
    function unserializes($data_value) { 
        $vars = preg_split( 
            ‘/([a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)\|/‘, 
            $data_value, -1, PREG_SPLIT_NO_EMPTY | 
            PREG_SPLIT_DELIM_CAPTURE 
        ); 
        for ($i = 0; isset($vars[$i]); $i++) { 
            $result[$vars[$i++]] = unserialize($vars[$i]); 
        } 
        return $result; 
    } 

    function open($path, $name) { 
        return true; 
    } 
    function close() { 
	    $this->gc($this->lasttime);
        return true; 
    } 
   function read($SessionKey){
	    $sql = "SELECT uid FROM sessions WHERE session_id = ‘".$SessionKey."‘ limit 1"; 
		$query =$this->db->query($sql);
		if($row=$this->db->fetch_array($query)){
		  return $row[‘uid‘];
		}else{
            return ""; 
		}
		 
   } 
    function write($SessionKey,$VArray) { 

	   require_once(MRoot.DIR_WS_CLASSES .‘db_mysql_class.php‘);
	   $db1=new DbCom();
	  // make a connection to the database... now
	   $db1->connect(DB_SERVER, DB_SERVER_USERNAME, DB_SERVER_PASSWORD, DB_DATABASE);
	   $db1->query("set names utf8");
	   $this->db=$db1;
       $SessionArray = addslashes($VArray);
		$data=$this->unserializes($VArray);	  
	    	 
		$sql0 = "SELECT uid FROM sessions WHERE session_id = ‘".$SessionKey."‘ limit 1"; 
		$query0 =$this->db->query($sql0);
		if($this->db->num_rows($query0)<=0){
			if (isset($data[‘webid‘]) && !empty($data[‘webid‘])) { 
			   $this->db->query("insert into `sessions` set `session_id` = ‘$SessionKey‘,uid=‘".$data[‘webid‘]."‘,last_visit=‘".time()."‘");
			} 		  
			return true;
		}else{
			/*$sql = "update `sessions` set "; 
			if(isset($data[‘webid‘])){
			$sql .= "uid = ‘".$data[‘webid‘]."‘, " ;
			}
			$sql.="`last_visit` = null " 
				  . "where `session_id` = ‘$SessionKey‘"; 
				 
			$this->db->query($sql); */
			return true; 
		}
    } 
  function destroy($SessionKey) { 
     $this->db->query("delete from `sessions` where `session_id` = ‘$SessionKey‘"); 
     return true; 
   } 
   function gc($lifetime) {
       $this->db->query("delete from `sessions` where unix_timestamp(now()) -`last_visit` > ‘".$this->lasttime."‘");
       return true;
   } 

  
} 
?>
时间: 2024-08-17 13:53:22

用session_set_save_handler函数实现将session保存在数据库中后session不能跨页面了的相关文章

ASP.NET将Session保存到数据库中

因为ASP.NET中Session的存取机制与ASP相同,都是保存在进行中, 一旦进程崩溃,所有Session信息将会丢失,所以我采取了将Session信息保存到SQL Server中,尽管还有其它的 几个方式(本文不作介绍),要将Session保存到SQL Server中,需要有以下几个步骤: 1.首先要创建用于保存Session数据的数据库,以命令行的形式用aspnet_regsql.exe来完成,具体命令为 C:\WINDOWS\Microsoft.NET\Framework\v2.0.5

Asp.Net将Session保存在数据库中

1.由于项目dll文件变动比较频繁,而保存登陆的状态又保存在Session中,所以导致用户经常无故掉线.(dll变动的时候导致Session丢失) 2.有一种方法可以长期保存session,那就是session的SqlServer模式.还是先介绍一下session的四种模式吧: ASP.NET会话状态模块在Web.config文件中<System.web>标记下的<Sessionstate>标记的mode属性来决定该属性的四种可能的值: Off. Inproc StateServe

Java中将图片保存到数据库中

在实际的开发中,我们可能需要将图片.影音等文件直接保存到数据库中,然后通过编程方式将数据读出进行使用.例如将读出的图片数据显示出来,将读出的电影文件播放出来. 二进制数据直接保存到文件和从文件中读出非常的简单.和普通的数据库操作差别不大.只是用到部分流操作.例如各种输入输出流操作.所以深刻理解流操是非常重要的. 在此我借助于一个JSP的简单实例进行讲解.此实例保存职员数据,其中职员数据包含一个图片列.此列保存每名员工的照片.在此将照片直接保存到数据库中.首先建立职员信息表EmployeeInfo

python爬取数据并保存到数据库中(第一次练手完整代码)

1.首先,下载需要的模块requests, BeautifulSoup, datetime, pymysql(注意,因为我用的python3.7,不支持mysqldb了),具体的下载方法有pip下载,或者使用Anaconda版本python的童鞋可以使用conda下载. 2.创建conndb,py,包含数据库的连接断开,增删改查等操作: #!/usr/bin/env python # -*- coding:utf-8 -*- import pymysql def conn_db(): # 连接数

Python爬虫项目,获取所有网站上的新闻,并保存到数据库中,解析html网页等

1.需求说明 需求: 爬取虎嗅网站的所有新闻,并保存到数据库中. http://www.huxiu.com 技术: 1.爬虫 获取服务器的资源(urllib) 解析html网页(BeautifulSoup) 2.数据库技术 数据库 MySQLdb 业务逻辑的分析: (1).虎嗅网站的新闻,包括首页和分页信息(下一页) (2).需要从首页的资源和分页的资源中获取每个新闻的url连接 如何获取url: 解析网站html文件,如果A标签的href属性包含 article字段,就表示这是一个新闻 (3)

FMDB使用的一点心得:数据库创建、制表、查询等以及image转换成二进制nsdata保存到数据库中

<span style="font-size:18px;">//首先,获取数据库的路径,(如果不存在,就是我们想要存储的路径),不用担心每次都创建数据库会重复,不会的,如果没有则创建,有了就不会再重复创建: //接下来,我们要制表,首先我们先查看我们的表是否已经存在,方法在下面代码中:如果存在则跳过,不存在则创建</span> -(void)DataBaseInit { //获取Document文件夹下的数据库文件,没有则创建 NSString *dbPath

将配置保存在数据库中

将配置保存在数据库中 我们在<聊聊默认支持的各种配置源>和<深入了解三种针对文件(JSON.XML与INI)的配置源>对配置模型中默认提供的各种ConfigurationSource进行了深入详尽的介绍,如果它们依然不能满足项目中的配置需求,我们可以还可以通过自定义ConfigurationProvider来支持我们希望的配置来源.就配置数据的持久化方式来说,将培植存储在数据库中应该是一种非常常见的方式,接下来我们就是创建一个针对数据库的ConfigurationSource,它采

将文件以二进制的形式保存到数据库中

主要应用HttpPostedFile类的InputStream属性.Stream类的read方法和Byte数据类型.首先获取上传数据文件的名称.大小和类型,建立一个访问客户端上传文件的对象HttpPostedFile和一个数据流对象Stream,然后使用数据流Stream对象将上传文件以二进制形式的数据写入Byte类型的数组中,最后将二进制数据保存的数据库中. 代码:try        {            if (this.FileUpload1.PostedFile.FileName

JQuery结合Ajax实现双击Table表格,使Table变成可编辑,并保存到数据库中

近期在做项目时,要实现通过双击Table表格的TR,使Table行变成可编辑,来实现修改数据并保存到数据库中的功能,无需多说,直接贴代码吧.希望能得到各位同仁指正. 1 function tdEdit(element, id) { 2 var i_a = "<input class='edit_td' type='text' style='height:30px; width:40px;' value='"; 3 var i_b = "'/>"; 4 v