通过session_set_save_handler实现自定义会话机制

先看代码,通过<code>session_set_save_handler</code>机制可以实现一个自定义的会话机制,依赖于mysql数据库

<?php

$sdbc=NULL;
function open_session(){
    global $sdbc;
    $sdbc=mysqli_connect("localhost","root","root",'test');
    if(mysqli_connect_errno($sdbc)){
        return false;
    }else{
        return true;
    }
}

function close_session(){
    global $sdbc;
    return mysqli_close($sdbc);
}

function read_session($sid){
    global $sdbc;
    $q=sprintf('SELECT * FROM session WHERE id="$s"',mysqli_real_escape_string($sdbc,$sid));
    $r=mysqli_query($sdbc,$q);
    if(mysqli_num_rows($r)==1){
        list($data)=mysqli_fetch_array($r,MYSQLI_NUM);
        return $data;
    }else{
        return"";
    }
}

function write_session($sid,$data){
    global $sdbc;
    $q=sprintf('REPLACE INTO session (id,data) VALUE ("$s","%s")',mysqli_real_escape_string($sdbc,$sid),mysqli_real_escape_string($sdbc,$data));
    $r=mysqli_query($sdbc,$q);
    return true;
}
function destroy_session($sid){
    global $sdbc;
    $q=sprintf('DELETE FROM session WHERE id="%s"',mysqli_real_escape_string($sdbc,$sid));
    $r=mysqli_query($sdbc,$q);
    $_SESSION=array();
}
function clean_session($expire){
    global $sdbc;
    $q=sprintf('DELETE FROM session WHERE DATE_ADD(last_accessed,INTERVAL $d SECOND )<NOW()0',(int)$expire);
    $r=mysqli_query($sdbc,$q);
    return true;
}

session_set_save_handler('open_session','close_session','read_session','write_session','destroy_session','clean_session');
session_start();

代码解释:

(1)<code>mysqli_connect</code>打开一个连接掉mysql数据库的连接,语法:<code>mysqli_connect('localhost','username','password','tablename')</code>

(2)<code>mysqli_connect_errno</code>返回上一次错误链接的错误代码。

(3)<code>sprintf</code>把其中的<code>%</code>换成一个作为参数传递的参数。

(4)<code>mysqli_query</code>针对mysql数据库进行操作,mysqli_query(database,query)。

(5)<code>mysqli_num_rows</code>返回结果集中行的数量。

(6)<code>mysqli_fetch_array</code>从结果中取得一行作为结果。

(7)<code>mysqli_real_escape_string</code>函数转义在 SQL 语句中使用的字符串中的特殊字符。语法:<code>myaqli_real_escape_string(database,word)</code>

(9)session_set_save_handler设置用户自定义会话存储函数。

推荐阅读更多精彩内容

  • php.ini设置,上传大文件: post_max_size = 128Mupload_max_filesize ...
    bycall阅读 6,003评论 3 64
  • sqlmap用户手册 说明:本文为转载,对原文中一些明显的拼写错误进行修正,并标注对自己有用的信息。 ======...
    wind_飘阅读 1,473评论 0 5
  • http://192.168.136.131/sqlmap/mysql/get_int.php?id=1 当给sq...
    xuningbo阅读 8,104评论 2 21
  • 本周小结 总得来说,本周没啥进展,不管是实验室工作还是自己的学习方面。周一:由于周末的重庆没有进入状态周二:导师就...
    im天行阅读 39评论 0 0
  • 中午听了一会儿樊登读书会里讲的《如何说孩子才会听,怎么听孩子才肯说》这本书,心里很受启发! 作为一名教师,真的感觉...
    神奇女侠ahua阅读 94评论 1 4