搜索
首页php教程php手册PHP用mysql数据库存储session

PHP用mysql数据库存储session

Jun 13, 2016 am 10:34 AM
mysqlphpsession使用存储数据库

大部分使用php的人一旦应用到session都会使用cookie。
cookie虽好可是它也会给我们带来一些隐患的。
隐患一:如果客户端机器的cookie一旦因病毒而失效了,那么session也就相当于没有了。
隐患二:session在php中默认的是以文件的形式保存在一个临时文件夹里面的,对于一个小型系统来说,这样做完全可以,
可是对于一个大型而又被经常访问的系统来说,就不是很好的办法了。假设这个网站一天有1000个人访问。一个月以后session的临时文件夹就会有30000个临时文件。想象一下计算机要从30000里面找一条session_sid是一个多么漫长的事情呀!
因此为了提高效率。
交易使用用数据库保存session。具体方法如下:
1.更改php.ini文件。
由于php默认保存session的方式是files所以我们要改变它。即:找到“session.save_handler = files”将“files”改为“User”。
把session的模式改成用户自定义的。
2.建立数据库:
CREATE TABLE `db_session` (
   `sesskey` char(32) NOT NULL,
   `expiry` int(11) unsigned NOT NULL,
   `value` text NOT NULL,
   PRIMARY KEY   (`sesskey`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
数据库表明:db_session
列名:sesskey,expiry,value 其中:sesskey为主键。
Value里面存放着session里面的值。
3.建立session_mysql.php文件。这个文件是用来构造保存session的方法的。修改一下参数直接使用就可以了。
session_mysql.php

复制PHP内容到剪贴板
PHP代码:

        $gb_DBname="db_myBBS";//数据库名称
       $gb_DBuser="root";//数据库用户名称
       $gb_DBpass="23928484";//数据库密码
       $gb_DBHOSTname="localhost";//主机的名称或是IP地址
      
       $SESS_DBH="";
       $SESS_LIFE=get_cfg_var("session.gc_maxlifetime");//得到session的最大有效期。
      
       function sess_open($save_path,$session_name){
               global $gb_DBHOSTname,$gb_DBname,$gb_DBuser,$gb_DBpass,$SESS_DBH;
               if(!$SESS_DBH=mysql_pconnect($gb_DBHOSTname,$gb_DBuser,$gb_DBpass)){
                      echo "

  • MySql Error:".mysql_error()."
  • ";
                          die();
                   }
                   if(!mysql_select_db($gb_DBname,$SESS_DBH)){
                          echo "
  • MySql Error:".mysql_error()."
  • ";
                          die();
                   }
                   return true;
            }
          
            function sess_close(){
                   return true;
            }
          
            function sess_read($key){
                   global $SESS_DBH,$SESS_LIFE;
                 $qry="select value from db_session 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=$val;
                  $qry="insert into db_session values($key,$expiry,$value)";
                  $qid=mysql_query($qry,$SESS_DBH);
                   if(!$qid){
                         $qry="update db_session 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 db_session where sesskey = $key";
                  $qid=mysql_query($qry,$SESS_DBH);
                   return $qid;
            }
          
            function sess_gc($maxlifetime){
                   global $SESS_DBH;
                  $qry="delete from db_session where expiry               $qid=mysql_query($qry,$SESS_DBH);
                  return mysql_affected_rows($SESS_DBH);
            }
           session_module_name();
        &n
  • 声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    AI Hentai Generator

    AI Hentai Generator

    免费生成ai无尽的。

    热门文章

    R.E.P.O.能量晶体解释及其做什么(黄色晶体)
    3 周前By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.最佳图形设置
    3 周前By尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O.如果您听不到任何人,如何修复音频
    3 周前By尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25:如何解锁Myrise中的所有内容
    3 周前By尊渡假赌尊渡假赌尊渡假赌

    热工具

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    适用于 Eclipse 的 SAP NetWeaver 服务器适配器

    将Eclipse与SAP NetWeaver应用服务器集成。

    MinGW - 适用于 Windows 的极简 GNU

    MinGW - 适用于 Windows 的极简 GNU

    这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    VSCode Windows 64位 下载

    VSCode Windows 64位 下载

    微软推出的免费、功能强大的一款IDE编辑器

    SublimeText3 英文版

    SublimeText3 英文版

    推荐:为Win版本,支持代码提示!