快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

在PHP3中实现SESSION的功能(一、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 = \\'\\';
}
}
?> 



返回类别: 教程
上一教程: PEAR:使用PHPDoc轻松建立你的PEAR文档
下一教程: 如何实现日期比较,暨实现显示5天内,显示10天内的记录

您可以阅读与"在PHP3中实现SESSION的功能(一、SESSION函数库:session.inc.php3)(转译)"相关的教程:
· 在PHP3中实现SESSION的功能(二、COOKIE函数库:cookie.inc.php3)(转译)
· 在PHP3中实现SESSION的功能(附、COOKIE函数库的使用:test_cookie.php3)
· 在PHP3中实现SESSION的功能(三、示例程序:test_session.php3)
· 在PHP3中实现SESSION的功能(二)
· 在PHP3中实现SESSION的功能(三)
    微笑服务 优质保证 索取样品