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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
session_set_save_handler函数是PHP用于设置自定义会话存储处理程序的函数。 会话是一种用于在不同页面和不同请求之间共享数据的机制。在默认情况下,PHP的会话数据是存储在服务器的临时文件的。然而,有时我们可能需要将会话数据存储在其他地方,比如数据库或者内存session_set_save_handler函数允许我们自定义会话存储处理程序,即我们可以指定自己定义的函数来处理会话数据的存储和检索。 我们需要传递一个数组作为参数给session_set_save_handler函数,这个数组包含了6个处理程序函数的名称。这些函数分别用于初始化会话处理程序、开启会话、关闭会话、读取会话数据、写入会话数据和销毁会话。 这些自定义的会话处理程序函数可以通过session_set_save_handler函数的调用来注册。一旦注册完成,PHP会在会话的不同阶段调用相应的函数来完成对会话数据的处理。 使用session_set_save_handler函数可以灵活地控制会话数据的存储方式,我们可以将会话数据存储在数据库,或者在某些情况下,我们可以将会话数据存储在内存以提高读写效率。 总而言之,session_set_save_handler函数是PHP用于配置自定义会话存储处理程序的函数。它允许我们通过注册自定义的会话处理程序函数来控制会话数据的存储方式。这使得我们可以根据自己的需求将会话数据存储在不同的地方,以提高性能和数据安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值