Home  >  Article  >  Backend Development  >  Customize session storage method in PHP_PHP tutorial

Customize session storage method in PHP_PHP tutorial

WBOY
WBOYOriginal
2016-07-13 17:51:191297browse

Description

In PHP, you can store server session data on different media by defining session_set_save_handler, such as in files, in apc or memcache cache, or in a database. You can count the number of people online, or kick out the login status of specific members, etc.

Customizing session_set_save_handler basically uses custom reading and writing methods to override the system's default session reading and writing methods to achieve session management. Everyone is welcome to communicate. If you have any questions, please write to me.


Factory class

[php]
 
/**
* CHttpSession
* http session data storage engine
​*/ 
 
class CHttpSession { 
 
    private static $engine; 
    private static $gc_maxlifetime; 
 
    public static function engine( $enginer ) { 
        $enginer        = ucfirst( $enginer ); 
        $engineInstance = "CHttpSession{$enginer}"; 
        $filename       = SYS_MODULE . '/Session/' . $engineInstance . '.php'; 
 
        if ( !file_exists( $filename )) { 
            throw new Exception( 'Fatal: not found {$filename} file' ); 
        } 
        require( $filename ); 
 
        if ( !class_exists( $engineInstance ) ) { 
            throw new Exception( 'Fatal: not found {$engineInstance} object' ); 
        } 
 
        $handler    = new CHttpSession( new $engineInstance ); 
 
        ini_set( "session.save_handler", "user" ); 
        ini_set( 'apc.ttl', 3600 ); 
        ini_set( 'apc.user_ttl', 1200 ); 
        ini_set( 'apc.gc_ttl', 3600 ); 
 
        session_set_save_handler( 
            array($handler, 'open'), 
            array($handler, 'close'), 
            array($handler, 'read'), 
            array($handler, 'write'), 
            array($handler, 'destroy'), 
            array($handler, 'gc') 
        ); 
         
        if ( isset( $_COOKIE['PHPSESSID'] ) ) { 
            session_start( $_COOKIE['PHPSESSID'] ); 
        } 
        else { 
            session_start( ); 
            setcookie( 'PHPSESSID', session_id(), null, '/', COOKIE_DOMAIN ); 
        } 
    } 
 
    public function __construct( & $engine ) { 
        self::$engine = $engine; 
        self::$gc_maxlifetime = ini_get( 'session.gc_maxlifetime' ); 
    } 
 
    public function read( $id ) { 
        return self::$engine->fetch( 'session/'.$id ); 
    } 
 
    public function write ( $id , $data ) { 
        return self::$engine->add( 'session/'.$id, $data, self::$gc_maxlifetime ); 
    } 
 
    public function close ( ) { 
        return true; 
    } 
 
 
    public function destroy ( $id ) { 
        return self::$engine->delete( 'session/'.$id ); 
    } 
 
    public function __destruct ( ) { 
        session_write_close(); 
    } 
 
 
    public function gc ( $maxlifetime ) { 
        return true; 
    } 
 
 
    public function open ( $save_path , $session_name ) { 
        return true; 
    } 
}; 

具体方法

CHttpSessionFile

[php]
 
/**
* CFileHttpSession
* Session engine, stores sessions in the form of files, YPi framework’s default session storage engine
* SESSION_DIR sets the session file storage path
​*/ 
 
 
class CHttpSessionFile { 
 
    public function add( $key, $data, $cg_maxlifetime ) { 
        $filepath = substr( $key, 7 ); 
        file_put_contents( SESSION_DIR.$filepath, $data ); 
        return true; 
    } 
 
    public function fetch( $key ) { 
        $filepath = substr( $key, 7 ); 
        if ( !file_exists(SESSION_DIR.$filepath) ) { 
            file_put_contents( SESSION_DIR.$filepath, '' ); 
            return true; 
        } 
        return file_get_contents( SESSION_DIR.$filepath ); 
    } 
 
    public function delete( $key ) { 
        $filepath = substr( $key, 7 ); 
        if ( file_exists( SESSION_DIR.$filepath ) ) { 
            unlink( SESSION_DIR.$filepath ); 
        } 
        return true; 
    } 
}; 


CHttpSessionApc

[php]
 
/**
* CApcHttpSession
* Session engine, stores sessions in the form of APC cache
* SESSION_ENGINE Set the value to apc to enable APC to store the session
​*/ 
 
 
class CHttpSessionApc { 
 
    public function add( $key, $data, $cg_maxlifetime ) { 
        apc_store( $key, $data, $cg_maxlifetime ); 
        return true; 
    } 
 
    public function fetch( $key ) { 
        if ( !apc_exists( $key ) ) { 
            apc_store( $key, '' ); 
            return true; 
        } 
        return apc_fetch( $key ); 
    } 
 
    public function delete( $key ) { 
        if ( apc_exists( $key ) ) { 
            apc_delete( $key ); 
        } 
        return true; 
    } 
}; 

CHttpSessionMemcache

[php]
 
/**
*CMemcacheHttpSession
* Session engine, stores sessions in the form of memcache cache *
* SESSION_ENGINE Set the value to memcache to enable memcache to store the session
* MEMCACHE_HOST Set memcache server address
* MEMCACHE_PORT Set memcache server access port number
​*/ 
 
 
class CHttpSessionMemcache { 
 
    private static $memcache; 
 
    public function __constrct( $config ) { 
        self::$memcache = new Memcache; 
        self::$memcache->connect( MEMCACHE_HOST, MEMCACHE_PORT ); 
    } 
 
    public function __destroy() { 
        self::$memcache->close(); 
    } 
 
    public function add( $key, $data, $cg_maxlifetime ) { 
        return self::$memcache->add( $key, $data, $cg_maxlifetime ); 
    } 
 
    public function fetch( $key ) { 
        return self::$memcache->get( $key ); 
    } 
 
    public function delete( $key ) { 
        return self::$memcache->delete( $key ); 
    } 
}; 


实例说明

只需要把平时用的 session_start() 替换成以下的方法即可。

[php]
 
defined('SESSION_ENGINE')||define('SESSION_ENGINE', 'file'); 
require '../lib/CHttpSession.php'; 
 
CHttpSession::engine( SESSION_ENGINE ); 

 


摘自 yagas的专栏

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/478213.htmlTechArticle描述 在PHP中可以通过定义session_set_save_handler,将服务器session数据存储在不同的介质上,比如存储在文件里,apc或memcache缓存中,或存储在数...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn