chaosxin 发表于 2015-8-30 12:08:53

Php中session_set_save_handler的含义

今天看手册,无意中看到了session_set_save_handler不解其意,于是上网搜寻得知,可以使用session_set_save_handler函数重载SESSION存储方式存储于MYSQL,样例如下:

Code
1<?php   
2   $DB_SERVER = "server"; /* database server hostname */
3   $DB_NAME = "dbname"; /* database name */
4   $DB_USER = "root"; /* database user */
5   $DB_PASS = "*************"; /* database password */
6   
7   $DB_SELECT_DB = "";
8   $SESS_LIFE = get_cfg_var("session.gc_maxlifetime");
9   
10function sess_open($save_path, $session_name) {
11global $DB_SERVER, $DB_NAME, $DB_USER, $DB_PASS, $DB_SELECT_DB;
12   
13if (! $DB_SELECT_DB = mysql_pconnect($DB_SERVER, $DB_USER, $DB_PASS)) {
14echo "SORRY! MYSQL ERROR : Can't connect to $DB_SERVER as $DB_USER";
15echo "MySQL Error: ", mysql_error();
16die;
17}
18   
19if (! mysql_select_db($DB_NAME, $DB_SELECT_DB)) {
20echo "SORRY! MYSQL ERROR : Unable to select database $DB_NAME";
21die;
22}
23   
24return true;
25}
26   
27function sess_close() {
28return true;
29}
30   
31function sess_read($SessionKey){
32      global $DB_SELECT_DB, $SESS_LIFE;   
33      $Query = "SELECT SessionArray FROM cdb_global_sessions WHERE SessionKey = '".$SessionKey."' AND SessionExpTime > " . time();
34      $Result = mysql_query($Query, $DB_SELECT_DB);
35   
36if (list($SessionArray) = mysql_fetch_row($Result)) {
37return $SessionArray;
38}
39   
40return false;
41}
42   
43function sess_write($SessionKey, $VArray) {
44global $DB_SELECT_DB, $SESS_LIFE;
45   
46$SessionExpTime = time() + $SESS_LIFE;
47$SessionArray = addslashes($VArray);
48   
49$Query = "INSERT INTO cdb_global_sessions (SessionKey,SessionExpTime,SessionArray) VALUES ('".$SessionKey."','".$SessionExpTime."','".$SessionArray."')";
50$Result = mysql_query($Query, $DB_SELECT_DB);
51   
52if (!$Result){
53$Query = "UPDATE cdb_global_sessions SET SessionExpTime = '".$SessionExpTime."', SessionArray = '".$SessionArray."' WHERE SessionKey = '".$SessionKey."' AND SessionExpTime > " . time();
54$Result = mysql_query($Query, $DB_SELECT_DB);
55}   
56return $Result;
57}
58   
59function sess_destroy($SessionKey) {
60global $DB_SELECT_DB;
61   
62$Query = "DELETE FROM cdb_global_sessions WHERE SessionKey = '".$SessionKey."'";
63$Result = mysql_query($Query, $DB_SELECT_DB);
64   
65return $Result;
66}
67   
68function sess_gc($maxlifetime) {
69global $DB_SELECT_DB;
70   
71$Query = "DELETE FROM cdb_global_sessions WHERE SessionExpTime < " . time();
72$Result = mysql_query($Query, $DB_SELECT_DB);
73   
74return mysql_affected_rows($DB_SELECT_DB);
75}
76   
77session_set_save_handler(
78"sess_open",
79"sess_close",
80"sess_read",
81"sess_write",
82"sess_destroy",
83"sess_gc");
84session_start();
85?>
86
页: [1]
查看完整版本: Php中session_set_save_handler的含义