在PHP3中实现SESSION的功能(一)

<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
SESSION函数库:SESSION.inc.PHP3

<?PHP
if (!isset($__SESSION_inc__)){
$__SESSION_inc__=1;
//require("cookie.inc.PHP3");
# -------------------------------------------------------------------  
# SESSION Management v1.0 21.6.1998  
# (c) Wild Karl Heinz <kh.wild@wicom.at>  
#  
# This Include handle SESSION based variable handling  
#  
# Please feel free and use it. If you make it more functional  
# it would be nice to send me a copy.  
#  
# Don’t forget - Mysql_connect !  
#  
# The database structure  
# Table structure for table ’SESSION’  
#  
# CREATE TABLE SESSION (  
# id int(11) DEFAULT ’0’ NOT NULL auto_increment,  
# sid varchar(20) DEFAULT ’’ NOT NULL,  
# val blob,  
# times timestamp(14),  
# PRIMARY KEY (id),  
# KEY sid (sid),  
# UNIQUE sid_2 (sid)  
# );  
#  
# You’ll miss here a cron job to delete the old SESSIONs from db  
# -------------------------------------------------------------------  

// 请注意上面被注释掉的CREATE TABLE语句,
// 你需要在你所使用的数据库上执行这条语句,
// 表名也可以不是SESSION,那么就需要设置下面的$sess_table变量了。

// 此处你需要设置库名,和表名。
// 不过一般建议就使用SESSION作为表名
$sess_db = ’dbname’;  
$sess_table = ’SESSION’;  

# ----------------------------------------------------  
# SESSION_CheckID - 检查、设置并返回 SESSION-ID  
# 参数......: cookie保存时间(以分钟计)
# 也可不设置表示这个 cookie 只在当前SESSION 有效
# 这其实就象ASP中SESSION的时效一样。
# 返回值....: 一个唯一的SESSION-ID (作为cookie存储)
# ----------------------------------------------------  
function SESSION_CheckID( $min )  
{
global $sess_sid;  

if( !$sess_sid ) {  
$sess_sid = uniqid( SC ); //取得一个唯一的随机数
/*
if( $min > 0 ) {  
SetCookie("sess_sid", $sess_sid, time()+($min*60), "/", "", 0 );  
}  
else {  
SetCookie("sess_sid", $sess_sid, "", "/", "", 0 );  
}  
上面是原先的代码,会出错。所以另外用了一个更好的函数。
函数库:cookie.inc.PHP3
*/
jssetcookie("sess_sid",$sess_sid,$min);
return( false );  
}  
else {  
return( true );  
}  
}  

# ----------------------------------------------------------  
# str2arr - 将字符串转换成SESSION数组
# 参数.....: string
# 返回值...: 全局数组(其实就是SESSION)  
#本函数用途:将字符串转换成SESSION数组
#如"SESSION[username]=yourid&SESSION[userpass]=12345"
#将会被转换成下面的数组
# SESSION[username]="yourid"
# SESSION[userpass]="12345"
#请注意函数split(),each(),list(),eval()的用法。
# ----------------------------------------------------------  
function str2arr( $ts )  
{  
global $SESSION;  

$vals = split( "&", $ts );  
while( list($key,$val) = each($vals) ) {  
list( $name, $wert ) = split( "=", $val );  
if( $val ) eval( "$$name = "$wert";" );  
}  
}  

# ----------------------------------------------------------  
# SESSION_read() - 从SESSION表中取数据,转换成SESSION数组  
# 参数........: 无
# 返回值......: 如果读出数据,返回 true ,否则返回 false
#注意.........: 用到了str2arr()这个函数
# ----------------------------------------------------------  
function SESSION_read()  
{  
# Hash array to keep SESSION-variables  
global $SESSION;  
global $sess_sid, $sess_db, $sess_table, $sess_error;  

$sel = "Select val from $sess_table where sid = ’$sess_sid’";  
$res = mysql_db_query( $sess_db, $sel );  
if( mysql_numrows( $res ) ) {  
$val = mysql_result( $res, 0, "val" );  
str2arr( $val );  
mysql_free_result( $res );  
return( true );  
}  
else {  
return( false );  
$sess_error = mysql_error();  
}  
}  

# ------------------------------------------------------  
# Split_Array() - 将SESSION数组转换成字符串
# 参数.......: 数组
# 返回值.....: 数组转换得来的字符串  
#  
# Thanks to Rasmus (这人好象是PHP的发明人)
# 注意:将SESSION数组转换成字符串
#如SESSION[username]="yourid"
# SESSION[userpass]="12345"
#将会被转换成"SESSION[username]=yourid&SESSION[userpass]=12345"
#同时该函数考虑到了数组的某个元素也是数据的情况
#这个函数被设计成一个递归函数
# ------------------------------------------------------  
function Split_Array( $arr, $a = "", $b = "", $c = "" )  
{  
while( list( $key, $val ) = each( $arr ) ) {  
if( is_array( $val ) ) {  
$ts .= Split_Array( $arr[ $key ],  
( strlen( $a ) ? $a : $key ),  
( strlen( $b ) ? $b : ( strlen( $a ) ? $key : "" ) ),  
( strlen( $c ) ? $c : ( strlen( $b ) ? $key : "" ) ) );  
}  
else {  
$ts .= "SESSION";  
$ts .= $a ? "[$a]" : "";  
$ts .= $b ? "[$b]" : "";  
$ts .= $c ? "[$c]" : "";  
$ts .= "[$key]=$val&";  
}  
}  
return( $ts );  
}  

# ---------------------------------------------------  
# SESSION_write - 将SESSION数组转换成字符串,再存到SESSION表中  
# 参数.: 无
# 返回值...: 如果存入正常返回 true ,否则返回 false
# ---------------------------------------------------  
function SESSION_write()  
{  
# Hash array to keep SESSION-variables  
global $SESSION;  

global $sess_sid, $sess_db, $sess_table;  
global $sess_error;  

# if you like to delete a SESSION-cookie  
# you must check it before writting the SESSION  
# array  

if( !$sess_sid ) { SESSION_checkid( 0 ); }  

$ts = Split_Array( $SESSION );  
if( $ts > "" ) { $ts = substr( $ts, 0, strlen( $ts ) - 1 ); }  
$res = mysql_db_query( $sess_db, "Select * from SESSION where sid = ’$sess_s’");  
if( mysql_numrows( $res ) == 0 ) {  
$sel = "Insert into $sess_table ( id, sid, val, times ) ";  
$sel .= "values( 0, ’$sess_sid’, ’$ts’, NULL )";  
}  
else {  
$sel = "Update $sess_table set val = ’$ts’, ";  
$sel .= "times = NULL where sid = ’$sess_sid’";  
}  
if( !mysql_db_query( $sess_db, $sel ) ) {  
$sess_error = mysql_error();  
return( false );  
}  
else { return( true ); }  
}  

# ---------------------------------------------  
# SESSION_del - 清除当前所有的SESSION
# 并删除SESSION表中和当前SESSION有关的记录  
# 参数.....: 一个随机的SESSION id  
# 返回值...: 无
# ---------------------------------------------  
function SESSION_del()  
{  
global $SESSION, $sess_db, $sess_table, $sess_sid;  

$sel = "Delete from $sess_table where sid = ’$sess_sid’";  
if( !mysql_db_query( $sess_db, $sel ) ) {  
$sess_error = mysql_error();
}
$sess_sid = ’’;
}
}
?>   
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 728x15, 创建于 08-4-23MSDN */ google_ad_slot = "3624277373"; google_ad_width = 728; google_ad_height = 15; //--> </script> <script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
<script type="text/javascript"><!-- google_ad_client = "pub-2947489232296736"; /* 160x600, 创建于 08-4-23MSDN */ google_ad_slot = "4367022601"; google_ad_width = 160; google_ad_height = 600; //--> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"> </script>
阅读更多
个人分类: 网络技术
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭
关闭