使用数据库保存session的方法 
php的session默认是以文件方式保存在服务器端,并且在客户端使用cookie保存变量,这就会出现一个问题,当一个用户由于某种安全原因关闭了浏览器的cookie,程序中的session相关操作将无法执行。因此,如果能以数据库保存session数据,将不受客户端设置的限制,并且在性能和扩展性等方面有一个飞跃。程序中使用关键函数是session_set_save_handler,同时要将php.ini里的session.save_handler = files 改为 user。这里我们讨论的环境是linux(freesd)+apache+mysql+php。

数据表结构:[sessions] 
CREATE TABLE sessions (  
sesskey char(32) not null,  
expiry int(11) unsigned not null,  
value text not null,  
PRIMARY KEY (sesskey)  
);

程序代码:[session_inc.php] 
<?php  
$SESS_DBHOST = "yourhost"; /* database server hostname */  
$SESS_DBNAME = "yourdb"; /* database name */  
$SESS_DBUSER = "youruser"; /* database user */  
$SESS_DBPASS = "yourpassword"; /* database password */  
  
$SESS_DBH = "";  
$SESS_LIFE = get_cfg_var("session.gc_maxlifetime");  
  
function sess_open($save_path, $session_name) {  
    global $SESS_DBHOST, $SESS_DBNAME, $SESS_DBUSER, $SESS_DBPASS, $SESS_DBH;  
  
    if (! $SESS_DBH = mysql_pconnect($SESS_DBHOST, $SESS_DBUSER, $SESS_DBPASS)) {  
        echo "<li>Can't connect to $SESS_DBHOST as $SESS_DBUSER";  
        echo "<li>MySQL Error: " . mysql_error();  
        die;  
    }  
  
    if (! mysql_select_db($SESS_DBNAME, $SESS_DBH)) {  
        echo "<li>Unable to select database $SESS_DBNAME";  
        die;  
    }  
  
    return true;  
}  
  
function sess_close() {  
    return true;  
}  
  
function sess_read($key) {  
    global $SESS_DBH, $SESS_LIFE;  
  
    $qry = "SELECT value FROM session_tbl WHERE sesskey = '$key' AND expiry > " . time();  
    $qid = mysql_query($qry, $SESS_DBH);  
  
    if (list($value) = mysql_fetch_row($qid)) {  
        return $value;  
    }  
  
    return false;  
}  
  
function sess_write($key, $val) {  
    global $SESS_DBH, $SESS_LIFE;  
  
    $expiry = time() + $SESS_LIFE; //过期时间  
    $value = addslashes($val);  
  
    $qry = "INSERT INTO session_tbl VALUES ('$key', $expiry, '$value')";  
    $qid = mysql_query($qry, $SESS_DBH);  
  
    if (! $qid) {&nbsp; 
        $qry = "UPDATE session_tbl SET expiry = $expiry, value = '$value' WHERE sesskey = '$key' AND expiry > " . time();  
        $qid = mysql_query($qry, $SESS_DBH);  
    }  
  
    return $qid;  
}  
  
function sess_destroy($key) {  
    global $SESS_DBH;  
  
    $qry = "DELETE FROM session_tbl WHERE sesskey = '$key'";  
    $qid = mysql_query($qry, $SESS_DBH);  
  
    return $qid;  
}  
  
function sess_gc($maxlifetime) {  
    global $SESS_DBH;  
  
    $qry = "DELETE FROM session_tbl WHERE expiry < " . time();  
    $qid = mysql_query($qry, $SESS_DBH);  
  
    return mysql_affected_rows($SESS_DBH);  
}  
  
session_set_save_handler(  
"sess_open",  
"sess_close",  
"sess_read",  
"sess_write",  
"sess_destroy",  
"sess_gc");  
  
session_start();  
?>

完成以上步骤后,在程序中使用require("session_inc.php")来代替session_start()即可,其他的session函数还是象以前一样的方法调用

双L5520 4*1T RAID 10 48G 10M 128ip 特价1800元/月 .联系老张-2881064151

如何使用数据库保存session的方法简介的更多相关文章

  1. 数据库保存session

    一般情况下,php.ini里的session.save_handler默认是file,也就是用文件来保存session,这种方式有几个缺点: 1.如果单靠session自己的垃圾回收机制,时间久了,保 ...

  2. Asp.Net保存session的三种方法 (Dll文件更新导致session丢失的解决办法)

    1. InProc模式(默认值):asp.net将session保存到当前进程中,这种方式最快,但是不能多台服务器共享session,且会话状态数据容易丢失. <sessionState mod ...

  3. [转]PHP用mysql数据库存储session

    From : http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2010/0226/4002.html 大部分使用php的人一旦应用到sessio ...

  4. PHP用mysql数据库存储session

    大部分使用php的人一旦应用到session都会使用cookie. cookie虽好可是它也会给我们带来一些隐患的. 隐患一:如果客户端机器的cookie一旦因病毒而失效了,那么session也就相当 ...

  5. Asp.Net 保存Session的三种方式

    一.默认方式,保存在IIS进程中保存在IIS进程中是指把Session数据保存在IIS的运行的进程中,也就是inetinfo.exe这个进程中,这也是默认的Session的存方式,也是最常用的. 这种 ...

  6. Asp.Net保存session的三种方法

    C#中保存Session的三种方法及Web.Config设置 1.保存session到sql server,需要指定Sql Server服务器,这种方法因为要读写数据库最慢 <sessionSt ...

  7. php面试题12(多态web服务器共享session的方法:将session存到数据库)($val=&$data[$key];)

    php面试题12(多态web服务器共享session的方法:将session存到数据库)($val=&$data[$key];) 一.总结 1.多态web服务器共享session的方法: ...

  8. 使用aspnet_regsql.exe 创建ASPState数据库,用来保存session会话

    使用aspnet_regsql.exe 创建ASPState数据库,用来保存session会话   因为公司有多台服务器,所以session要保存在sql server上,因此要在数据库中建立存放se ...

  9. laravel中将session由文件保存改为数据库保存

    1.laravel中默认是使用文件保存session的,保存在/storage/framework/sessions下 2.修改配置文件 config/session.php中 'driver' =& ...

随机推荐

  1. WPF 打印控件 无弹框打印。

    WPF中打印用到了 PrintDialog类. 其中设置打印属性的是PrintTicket,管理打印机的是PrintQueue. 实例如下: public class PrintDialogHelpe ...

  2. Java for LeetCode 072 Edit Distance【HARD】

    Given two words word1 and word2, find the minimum number of steps required to convert word1 to word2 ...

  3. Java for LeetCode 033 Search in Rotated Sorted Array

    Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...

  4. c++ template函数的声明和实现需要在同一个文件中

    新建一个class C;生成2个文件C.h和C.cpp,在C.h中声明一个函数 template<class T> T stringTo(char* str); 直接用VAssistX的R ...

  5. Doodle Poll 投票文档

    使用Doodle Poll网页文件可以让大家投票看什么时间大家都合适.

  6. iOS的I/O操作

    一般而言,处理文件时都要经历以下四个步骤: 1.创建文件 2.打开文件,以便在后面的I/O操作中引用该文件 3.对打开的文件执行I/O操作(读取.写入.更新) 4.关闭文件 iOS中,对文件常见的处理 ...

  7. Kafka学习笔记(一):概念介绍

    Kafka是一个开源的,分布式的,高吞吐量的消息系统.随着Kafka的版本迭代,日趋成熟.大家对它的使用也逐步从日志系统衍生到其他关键业务领域.特别是其超高吞吐量的特性,在互联网领域,使用越来越广泛, ...

  8. laravel 分页

    因为Laravel默认使用的是en语言文件所有咱们相应使用中文分页提示的话,可以按如下步骤操作: laravel4------------------------------------------- ...

  9. Failed to load or instantiate

    Failed to load or instantiate: add this code in your xml: xmlns:android="http://schemas.android ...

  10. C++ windows遍历目录

    bool Search(TCHAR *Path,TCHAR *File) { HANDLE hFind; WIN32_FIND_DATA wfd; ZeroMemory(&wfd,sizeof ...