美文网首页
通过session_set_save_handler实现自定义会

通过session_set_save_handler实现自定义会

作者: MakingChoice | 来源:发表于2016-07-01 00:05 被阅读805次

    先看代码,通过<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设置用户自定义会话存储函数。

    相关文章

      网友评论

          本文标题:通过session_set_save_handler实现自定义会

          本文链接:https://www.haomeiwen.com/subject/ehefjttx.html