セッション変数を書き込み、読み込み、破壊PHPサンプル

ファイル名:session.class.php

サンプルコード:

<?php
class session
{
static function init()
{
session_set_save_handler(
array(“session","open"),
array(“session","close"),
array(“session","read"),
array(“session","write"),
array(“session","destroy"),
array(“session","gc")
);
}

static function open($save_path,$session_name)
{
echo “session opening!<br>";
/*global $db,$REMOTE_ADDR;
$rs = $db->Execute(“select * from Sessions where SessionID='".session_id()."'");
$arry=$rs->FetchRow();
if( $rs && $arry)
{
$db->Execute(“update Sessions set SessionLast=NOW() where SessionID='".session_id()."'");
}
else
{
$query = “insert into Sessions set SessionID='".session_id()."',SessionName=’$REMOTE_ADDR’,SessionLast=’NOW()'";
//echo $query;
$db->Execute($query);
}*/
return true;
}
static function close()
{
return(true);
}

static function read($id)
{
echo “セッションを読み込む<br>";
global $db;
return true;
$timenow = strftime(“%Y-%m-%d %H:%M:%S", time());
$query = “select SessionData from Sessions where SessionID=’$id’ and SessionLast > '$timenow'";
$rs = $db->Execute($query);
if(list($SessionData) = $rs->FetchRow())
{
//echo $SessionData;
return $SessionData;
}
else
{
return false;
}
}

static function write($id,$sess_data)
{
echo “セッションを書き込む!<br>";
global $db;
$rs = $db->Execute(“select SessionID from Sessions where SessionID=’$id'");
$num = $rs->RecordCount();
$unix_time = time()+MY_SESS_TIME;
//echo MY_SESS_TIME;
$dateleft = strftime(“%Y-%m-%d %H:%M:%S", $unix_time);
if($num <= 0)
{
$sql = “insert into Sessions set SessionData=’$sess_data’, SessionName='".$_SERVER[“REMOTE_ADDR"]."', SessionLast=’$dateleft’, SessionID='".session_id()."'";
}
else
{
$sql = “update Sessions set SessionData=’$sess_data’, SessionName='".$_SERVER[“REMOTE_ADDR"]."', SessionLast=’$dateleft’ where SessionID=’$id'";
}
$db->Execute($sql);
}

static function destroy($id)
{
echo “セッションを破壊<br>";
global $db;
$sql = “DELETE FROM Sessions WHERE `SessionID` = '$id'";
$rs = $db->Execute($sql);
return $rs;
// $sess_file = “$sess_save_path/sess_$id";
//return(@unlink($sess_file));
}

/*********************************************
* WARNING – You will need to implement some *
* sort of garbage collection routine here. *
*********************************************/
static function gc($maxlifetime)
{
echo “セッションのガーベッジコレクション!<br>";
global $db;
$timenow = strftime(“%Y-%m-%d %H:%M:%S", time());
$sql = “DELETE FROM `$table_sessions` WHERE `SessionLast` < '$timenow'";
return $sess_db->Execute($sql);
//echo “now gc!<br>";
return true;
}
// proceed to use sessions normally
}

Source

Posted by arkgame