ホームページ  >  記事  >  バックエンド開発  >  session_set_save_handler的调用过程是如何样的

session_set_save_handler的调用过程是如何样的

WBOY
WBOYオリジナル
2016-06-13 10:08:10792ブラウズ

session_set_save_handler的调用过程是怎么样的?

PHP code
<!--Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--><?php /**CREATE TABLE IF NOT EXISTS `sessions` (  `session` varchar(255) character set utf8 collate utf8_bin NOT NULL,  `session_expires` int(10) unsigned NOT NULL default '0',  `session_data` text collate utf8_unicode_ci,  PRIMARY KEY  (`session`)) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci; */class Session {    /**     * a database connection resource     * @var resource     */    private static $_sess_db;    /**     * Open the session     * @return bool     */    public static function open() {                if (self::$_sess_db = mysql_connect('localhost', 'root', '')) {            return mysql_select_db('my_application', self::$_sess_db);        }        return false;    }    /**     * Close the session     * @return bool     */    public static function close() {        return mysql_close(self::$_sess_db);    }    /**     * Read the session     * @param int session id     * @return string string of the sessoin     */    public static function read($id) {        $id = mysql_real_escape_string($id);        $sql = sprintf("SELECT `session_data` FROM `sessions` WHERE `session` = '%s'", $id);        if ($result = mysql_query($sql, self::$_sess_db)) {            if (mysql_num_rows($result)) {                $record = mysql_fetch_assoc($result);                return $record['session_data'];            }        }        return '';    }    /**     * Write the session     * @param int session id     * @param string data of the session     */    public static function write($id, $data) {        $sql = sprintf("REPLACE INTO `sessions` VALUES('%s', '%s', '%s')",                       mysql_real_escape_string($id),                       mysql_real_escape_string(time()),                       mysql_real_escape_string($data)                       );        return mysql_query($sql, self::$_sess_db);    }    /**     * Destoroy the session     * @param int session id     * @return bool     */    public static function destroy($id) {        $sql = sprintf("DELETE FROM `sessions` WHERE `session` = '%s'", $id);        return mysql_query($sql, self::$_sess_db);    }    /**     * Garbage Collector     * @param int life time (sec.)     * @return bool     * @see session.gc_divisor      100     * @see session.gc_maxlifetime 1440     * @see session.gc_probability    1     * @usage execution rate 1/100     *        (session.gc_probability/session.gc_divisor)     */    public static function gc($max) {        $sql = sprintf("DELETE FROM `sessions` WHERE `session_expires` < '%s'",                       mysql_real_escape_string(time() - $max));        return mysql_query($sql, self::$_sess_db);    }}//ini_set('session.gc_probability', 50);ini_set('session.save_handler', 'user');session_set_save_handler(array('Session', 'open'),                         array('Session', 'close'),                         array('Session', 'read'),                         array('Session', 'write'),                         array('Session', 'destroy'),                         array('Session', 'gc')                         );if (session_id() == "") session_start();//session_regenerate_id(false); //also works fineif (isset($_SESSION['counter'])) {    $_SESSION['counter']++;} else {    $_SESSION['counter'] = 1;}echo '<br/>SessionID: '. session_id() .'<br>Counter: '. $_SESSION['counter'];


"open" /* session_start()调用 */  
"close" /* 程序结束时调用 */  
"read" /* session_start()调用 */  
"write" /* 程序结束时调用 */  
"destroy" /* session_destroy()调用 */  
"gc" /* 操作系统gc进程调用 */

上面是我从网上的例子中看到的(原文链接http://blog.csdn.net/zf213/archive/2009/06/22/4288567.aspx)
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。