Php中session_set_save_handler的含义


 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    
10  function sess_open($save_path, $session_name) { 
11  global $DB_SERVER, $DB_NAME, $DB_USER, $DB_PASS, $DB_SELECT_DB
12   
13  if (! $DB_SELECT_DB = mysql_pconnect($DB_SERVER, $DB_USER, $DB_PASS)) { 
14  echo "SORRY! MYSQL ERROR : Can't connect to $DB_SERVER as $DB_USER"
15  echo "MySQL Error: ", mysql_error(); 
16  die
17  } 
18   
19  if (! mysql_select_db($DB_NAME, $DB_SELECT_DB)) { 
20  echo "SORRY! MYSQL ERROR : Unable to select database $DB_NAME"
21  die
22  } 
23   
24  return true
25  } 
26   
27  function sess_close() { 
28  return true
29  } 
30   
31  function 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   
36  if (list($SessionArray= mysql_fetch_row($Result)) { 
37  return $SessionArray
38  } 
39   
40  return false
41  } 
42   
43  function sess_write($SessionKey, $VArray) { 
44  global $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   
52  if (!$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  }    
56  return $Result
57  } 
58   
59  function sess_destroy($SessionKey) { 
60  global $DB_SELECT_DB
61   
62  $Query = "DELETE FROM cdb_global_sessions WHERE SessionKey = '".$SessionKey."'"
63  $Result = mysql_query($Query, $DB_SELECT_DB); 
64   
65  return $Result
66  } 
67   
68  function sess_gc($maxlifetime) { 
69  global $DB_SELECT_DB
70   
71  $Query = "DELETE FROM cdb_global_sessions WHERE SessionExpTime < " . time(); 
72  $Result = mysql_query($Query, $DB_SELECT_DB); 
73   
74  return mysql_affected_rows($DB_SELECT_DB); 
75  } 
76   
77  session_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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值