<?
$DB_SERVER = "сервер"; /* имя хоста сервера базы данных */
$DB_NAME = "имя базы данных"; /* имя базы данных */
$DB_USER = "корень"; /* пользователь базы данных */
$DB_PASS = "************"; /* пароль базы данных */
$DB_SELECT_DB = "";
$SESS_LIFE = get_cfg_var("session.gc_maxlifetime");
функция sess_open($save_path, $session_name) {
глобальный $DB_SERVER, $DB_NAME, $DB_USER, $DB_PASS, $DB_SELECT_DB;
if (! $DB_SELECT_DB = mysql_pconnect($DB_SERVER, $DB_USER, $DB_PASS)) {
echo "ИЗВИНИТЕ! ОШИБКА MYSQL: невозможно подключиться к $DB_SERVER как $DB_USER";
echo "Ошибка MySQL: ", mysql_error();
умереть;
}
if (! mysql_select_db($DB_NAME, $DB_SELECT_DB)) {
echo "ИЗВИНИТЕ! ОШИБКА MYSQL: невозможно выбрать базу данных $DB_NAME";
умереть;
}
Вернуть истину;
}
функция sess_close() {
вернуть истину;
}
функция sess_read($SessionKey){
глобальный $DB_SELECT_DB, $SESS_LIFE;
$Query = "ВЫБРАТЬ SessionArray ИЗ cdb_global_sessions WHERE SessionKey = '".$SessionKey."' И SessionExpTime > " . время();
$Result = mysql_query($Query, $DB_SELECT_DB);
if (list($SessionArray) = mysql_fetch_row($Result)) {
вернуть $SessionArray;
}
Вернуть ложь;
}
функция sess_write($SessionKey, $VArray) {
глобальный $DB_SELECT_DB, $SESS_LIFE;
$SessionExpTime = время() + $SESS_LIFE;
$SessionArray = addslashes($VArray);
$Query = "INSERT INTO cdb_global_sessions (SessionKey,SessionExpTime,SessionArray) ЗНАЧЕНИЯ ('".$SessionKey."','".$SessionExpTime."','".$SessionArray."')";
$Result = mysql_query($Query, $DB_SELECT_DB);
если (!$Результат){
$Query = "UPDATE cdb_global_sessions SET SessionExpTime = '".$SessionExpTime."', SessionArray = '".$SessionArray."' WHERE SessionKey = '".$SessionKey."' И SessionExpTime > " . время();
$Result = mysql_query($Query, $DB_SELECT_DB);
}
вернуть $Результат;
}
функция sess_destroy($SessionKey) {
глобальный $DB_SELECT_DB;
$Query = "УДАЛЕНИЕ ИЗ cdb_global_sessions WHERE SessionKey = '".$SessionKey."'";
$Result = mysql_query($Query, $DB_SELECT_DB);
вернуть $Результат;
}
функция sess_gc($maxlifetime) {
глобальный $DB_SELECT_DB;
$Query = "УДАЛЕНИЕ ИЗ cdb_global_sessions WHERE SessionExpTime < " . время();
$Result = mysql_query($Query, $DB_SELECT_DB);
вернуть mysql_affected_rows($DB_SELECT_DB);
}
session_set_save_handler(
"sess_open",
"сесс_закрыть",
"сесс_чтение",
"сесс_запись",
"sess_destroy",
"сесс_гк");
сеанс_start();
?>