ホームページ  >  記事  >  バックエンド開発  >  session_set_save_handler 関数を使用して SESSION ストレージ メソッドをオーバーロードするための MYSQL_PHP チュートリアル

session_set_save_handler 関数を使用して SESSION ストレージ メソッドをオーバーロードするための MYSQL_PHP チュートリアル

WBOY
WBOYオリジナル
2016-07-13 17:36:20959ブラウズ

$DB_SERVER = "サーバー"; /* データベース サーバーのホスト名 */
$DB_NAME = "dbname"; /* データベース名 */
$DB_USER = "root"; /* データベース ユーザー */
$DB_PASS = "*************"; /* データベースのパスワード */

$DB_SELECT_DB = "";
$SESS_LIFE = get_cfg_var("session.gc_maxlifetime");

function sess_open($save_path, $session_name) {
global $DB_SERVER, $DB_NAME, $DB_USER, $DB_PASS, $DB_SELECT_DB;

if (! $DB_SELECT_DB = mysql_pconnect($DB_SERVER, $DB_USER, $DB_PASS)) {
echo "SORRY! MYSQL ERROR : $DB_USER として $DB_SERVER に接続できません";
echo "MySQL エラー: ", mysql_error();
死ね;
}

if (! mysql_select_db($DB_NAME, $DB_SELECT_DB)) {
echo "SORRY! MYSQL エラー: データベース $DB_NAME を選択できません";
die;
}

true を返す;
}

function sess_close() {
return true;
}

function sess_read($SessionKey){
global $DB_SELECT_DB, $SESS_LIFE;
$Query = "SELECT SessionArray FROM cdb_global_sessions WHERE SessionKey = ".$SessionKey." AND SessionExpTime > " 。 time();
$Result = mysql_query($Query, $DB_SELECT_DB);

if (list($SessionArray) = mysql_fetch_row($Result)) {
return $SessionArray;
}

return false;
}

function sess_write($SessionKey, $VArray) {
global $DB_SELECT_DB, $SESS_LIFE;

$SessionExpTime = time() + $SESS_LIFE;
$SessionArray = addlashes($VArray);

$Query = "INSERT INTO cdb_global_sessions (SessionKey,SessionExpTime,SessionArray) VALUES (".$SessionKey.",".$SessionExpTime.",".$SessionArray.")";
$Result = mysql_query($Query, $ DB_SELECT_DB);

if (!$Result){
$Query = "UPDATE cdb_global_sessions SET SessionExpTime = ".$SessionExpTime.", SessionArray = ".$SessionArray." WHERE SessionKey = ".$SessionKey." AND SessionExpTime > " . time();
$Result = mysql_query($Query, $DB_SELECT_DB);
}
return $Result;
}

function sess_destroy($SessionKey) {
global $DB_SELECT_DB;

$Query = "DELETE FROM cdb_global_sessions WHERE SessionKey = ".$SessionKey."";
$Result = mysql_query($Query, $DB_SELECT_DB);

return $Result;
}

function sess_gc($maxlifetime) {
global $DB_SELECT_DB;

$Query = "cdb_global_sessions WHERE SessionExpTime < " から削除します。 time();
$Result = mysql_query($Query, $DB_SELECT_DB);

return mysql_affected_rows($DB_SELECT_DB);
}

session_set_save_handler(
"sess_open",
"sess_close",
"sess_read",
"sess_write",
"sess_destroy",
"sess_gc");

session_start();
?>

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/508230.html技術記事 ? $DB_SERVER = "サーバー"; /* データベース サーバーのホスト名 */ $DB_NAME = "dbname"; /* データベース名 */ $DB_USER = "root"; /* データベース ユーザー */ $DB_PASS = "*************"; /* データベースパス...
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。