


在PHP3中實(shí)現(xiàn)SESSION的功能(一、SESSION函數(shù)庫(kù):session.inc.php3)(轉(zhuǎn)譯)
Jun 21, 2016 am 09:13 AMsession|函數(shù)
if (!isset($__session_inc__)){
$__session_inc__=1;
//require("cookie.inc.php3");
# -------------------------------------------------------------------
# Session Management v1.0 21.6.1998
# (c) Wild Karl Heinz
#
# 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
# -------------------------------------------------------------------
// 請(qǐng)注意上面被注釋掉的CREATE TABLE語(yǔ)句,
// 你需要在你所使用的數(shù)據(jù)庫(kù)上執(zhí)行這條語(yǔ)句,
// 表名也可以不是session,那么就需要設(shè)置下面的$sess_table變量了。
// 此處你需要設(shè)置庫(kù)名,和表名。
// 不過(guò)一般建議就使用session作為表名
???$sess_db = 'dbname';
???$sess_table = 'session';
???
# ----------------------------------------------------
# Session_CheckID - 檢查、設(shè)置并返回 Session-ID
# 參數(shù)......: cookie保存時(shí)間(以分鐘計(jì))
#?????????????也可不設(shè)置表示這個(gè) cookie 只在當(dāng)前session 有效
#?????????????這其實(shí)就象ASP中SESSION的時(shí)效一樣。
# 返回值....: 一個(gè)唯一的Session-ID (作為cookie存儲(chǔ))
# ----------------------------------------------------
function Session_CheckID( $min )
{
????global $sess_sid;
????if( !$sess_sid ) {
??????$sess_sid = uniqid( SC ); //取得一個(gè)唯一的隨機(jī)數(shù)
/*
??????if( $min > 0 ) {
?????????SetCookie("sess_sid", $sess_sid, time()+($min*60), "/", "", 0 );
?????????}
??????else {
?????????SetCookie("sess_sid", $sess_sid, "", "/", "", 0 );
?????????}
上面是原先的代碼,會(huì)出錯(cuò)。所以另外用了一個(gè)更好的函數(shù)。
函數(shù)庫(kù):cookie.inc.php3
*/
????????jssetcookie("sess_sid",$sess_sid,$min);
??????return( false );
??????}
???else {
??????return( true );
??????}
}
# ----------------------------------------------------------
# str2arr - 將字符串轉(zhuǎn)換成session數(shù)組
# 參數(shù).....: string
# 返回值...: 全局?jǐn)?shù)組(其實(shí)就是session)
#本函數(shù)用途:將字符串轉(zhuǎn)換成session數(shù)組
#如"session[username]=yourid&session[userpass]=12345"
#將會(huì)被轉(zhuǎn)換成下面的數(shù)組
#??session[username]="yourid"
#??session[userpass]="12345"
#請(qǐng)注意函數(shù)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表中取數(shù)據(jù),轉(zhuǎn)換成session數(shù)組
# 參數(shù)........: 無(wú)
# 返回值......: 如果讀出數(shù)據(jù),返回 true ,否則返回 false
#注意.........: 用到了str2arr()這個(gè)函數(shù)
# ----------------------------------------------------------
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數(shù)組轉(zhuǎn)換成字符串
# 參數(shù).......: 數(shù)組
# 返回值.....: 數(shù)組轉(zhuǎn)換得來(lái)的字符串
#
# Thanks to Rasmus (這人好象是PHP的發(fā)明人)
# 注意:將session數(shù)組轉(zhuǎn)換成字符串
#如session[username]="yourid"
#??session[userpass]="12345"
#將會(huì)被轉(zhuǎn)換成"session[username]=yourid&session[userpass]=12345"
#同時(shí)該函數(shù)考慮到了數(shù)組的某個(gè)元素也是數(shù)據(jù)的情況
#這個(gè)函數(shù)被設(shè)計(jì)成一個(gè)遞歸函數(shù)
# ------------------------------------------------------
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數(shù)組轉(zhuǎn)換成字符串,再存到session表中
# 參數(shù).: 無(wú)
# 返回值...: 如果存入正常返回 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 - 清除當(dāng)前所有的session
#???????????????并刪除session表中和當(dāng)前session有關(guān)的記錄
# 參數(shù).....: 一個(gè)隨機(jī)的session id
# 返回值...: 無(wú)
# ---------------------------------------------
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 = '';
}
}
?>?

熱AI工具

Undress AI Tool
免費(fèi)脫衣圖片

Undresser.AI Undress
人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強(qiáng)大的PHP整合開(kāi)發(fā)環(huán)境

Dreamweaver CS6
視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版
神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

「你的組織要求你更改PIN訊息」將顯示在登入畫(huà)面上。當(dāng)在使用基於組織的帳戶設(shè)定的電腦上達(dá)到PIN過(guò)期限制時(shí),就會(huì)發(fā)生這種情況,在該電腦上,他們可以控制個(gè)人設(shè)備。但是,如果您使用個(gè)人帳戶設(shè)定了Windows,則理想情況下不應(yīng)顯示錯(cuò)誤訊息。雖然情況並非總是如此。大多數(shù)遇到錯(cuò)誤的使用者使用個(gè)人帳戶報(bào)告。為什麼我的組織要求我在Windows11上更改我的PIN?可能是您的帳戶與組織相關(guān)聯(lián),您的主要方法應(yīng)該是驗(yàn)證這一點(diǎn)。聯(lián)絡(luò)網(wǎng)域管理員會(huì)有所幫助!此外,配置錯(cuò)誤的本機(jī)原則設(shè)定或不正確的登錄項(xiàng)目也可能導(dǎo)致錯(cuò)誤。即

Windows11將清新優(yōu)雅的設(shè)計(jì)帶到了最前沿;現(xiàn)代介面可讓您個(gè)性化和更改最精細(xì)的細(xì)節(jié),例如視窗邊框。在本指南中,我們將討論逐步說(shuō)明,以協(xié)助您在Windows作業(yè)系統(tǒng)中建立反映您的風(fēng)格的環(huán)境。如何更改視窗邊框設(shè)定?按+開(kāi)啟“設(shè)定”應(yīng)用程式。 WindowsI前往個(gè)人化,然後按一下顏色設(shè)定。顏色變更視窗邊框設(shè)定視窗11「寬度=」643「高度=」500「>找到在標(biāo)題列和視窗邊框上顯示強(qiáng)調(diào)色選項(xiàng),然後切換它旁邊的開(kāi)關(guān)。若要在「開(kāi)始」功能表和工作列上顯示主題色,請(qǐng)開(kāi)啟「在開(kāi)始」功能表和工作列上顯示主題

預(yù)設(shè)情況下,Windows11上的標(biāo)題列顏色取決於您選擇的深色/淺色主題。但是,您可以將其變更為所需的任何顏色。在本指南中,我們將討論三種方法的逐步說(shuō)明,以更改它並個(gè)性化您的桌面體驗(yàn),使其具有視覺(jué)吸引力。是否可以更改活動(dòng)和非活動(dòng)視窗的標(biāo)題列顏色?是的,您可以使用「設(shè)定」套用變更活動(dòng)視窗的標(biāo)題列顏色,也可以使用登錄編輯程式變更非活動(dòng)視窗的標(biāo)題列顏色。若要了解這些步驟,請(qǐng)前往下一部分。如何在Windows11中變更標(biāo)題列的顏色? 1.使用「設(shè)定」應(yīng)用程式按+開(kāi)啟設(shè)定視窗。 WindowsI前往“個(gè)人化”,然

工作列縮圖可能很有趣,但它們也可能分散注意力或煩人??紤]到您將滑鼠懸停在該區(qū)域的頻率,您可能無(wú)意中關(guān)閉了重要視窗幾次。另一個(gè)缺點(diǎn)是它使用更多的系統(tǒng)資源,因此,如果您一直在尋找一種提高資源效率的方法,我們將向您展示如何停用它。不過(guò),如果您的硬體規(guī)格可以處理它並且您喜歡預(yù)覽版,則可以啟用它。如何在Windows11中啟用工作列縮圖預(yù)覽? 1.使用「設(shè)定」應(yīng)用程式點(diǎn)擊鍵並點(diǎn)選設(shè)定。 Windows按一下系統(tǒng),然後選擇關(guān)於。點(diǎn)選高級(jí)系統(tǒng)設(shè)定。導(dǎo)航至“進(jìn)階”選項(xiàng)卡,然後選擇“效能”下的“設(shè)定”。在「視覺(jué)效果」選

您是否在Windows安裝程式頁(yè)面上看到「出現(xiàn)問(wèn)題」以及「OOBELANGUAGE」語(yǔ)句? Windows的安裝有時(shí)會(huì)因此類錯(cuò)誤而停止。 OOBE表示開(kāi)箱即用的體驗(yàn)。正如錯(cuò)誤提示所表示的那樣,這是與OOBE語(yǔ)言選擇相關(guān)的問(wèn)題。沒(méi)有什麼好擔(dān)心的,你可以透過(guò)OOBE螢?zāi)槐旧淼钠猎]冊(cè)表編輯來(lái)解決這個(gè)問(wèn)題??焖傩迯?fù)–1.點(diǎn)選OOBE應(yīng)用底部的「重試」按鈕。這將繼續(xù)進(jìn)行該過(guò)程,而不會(huì)再打嗝。 2.使用電源按鈕強(qiáng)制關(guān)閉系統(tǒng)。系統(tǒng)重新啟動(dòng)後,OOBE應(yīng)繼續(xù)。 3.斷開(kāi)系統(tǒng)與網(wǎng)際網(wǎng)路的連接。在脫機(jī)模式下完成OOBE的所

在Windows11上的顯示縮放方面,我們都有不同的偏好。有些人喜歡大圖標(biāo),有些人喜歡小圖標(biāo)。但是,我們都同意擁有正確的縮放比例很重要。字體縮放不良或圖像過(guò)度縮放可能是工作時(shí)真正的生產(chǎn)力殺手,因此您需要知道如何自訂以充分利用系統(tǒng)功能。自訂縮放的優(yōu)點(diǎn):對(duì)於難以閱讀螢?zāi)簧系奈淖值娜藖?lái)說(shuō),這是一個(gè)有用的功能。它可以幫助您一次在螢?zāi)簧喜榭锤鄡?nèi)容。您可以建立僅適用於某些監(jiān)視器和應(yīng)用程式的自訂擴(kuò)充功能設(shè)定檔。可以幫助提高低階硬體的效能。它使您可以更好地控制螢?zāi)簧系膬?nèi)容。如何在Windows11

螢?zāi)涣炼仁鞘褂矛F(xiàn)代計(jì)算設(shè)備不可或缺的一部分,尤其是當(dāng)您長(zhǎng)時(shí)間注視螢?zāi)粫r(shí)。它可以幫助您減輕眼睛疲勞,提高易讀性,並輕鬆有效地查看內(nèi)容。但是,根據(jù)您的設(shè)置,有時(shí)很難管理亮度,尤其是在具有新UI更改的Windows11上。如果您在調(diào)整亮度時(shí)遇到問(wèn)題,以下是在Windows11上管理亮度的所有方法。如何在Windows11上變更亮度[10種方式解釋]單一顯示器使用者可以使用下列方法在Windows11上調(diào)整亮度。這包括使用單一顯示器的桌上型電腦系統(tǒng)以及筆記型電腦。讓我們開(kāi)始吧。方法1:使用操作中心操作中心是訪問(wèn)

Windows上的啟動(dòng)過(guò)程有時(shí)會(huì)突然轉(zhuǎn)向顯示包含此錯(cuò)誤代碼0xc004f069的錯(cuò)誤訊息。雖然啟動(dòng)程序已經(jīng)聯(lián)機(jī),但一些運(yùn)行WindowsServer的舊系統(tǒng)可能會(huì)遇到此問(wèn)題。透過(guò)這些初步檢查,如果這些檢查不能幫助您啟動(dòng)系統(tǒng),請(qǐng)?zhí)街饕鉀Q方案以解決問(wèn)題。解決方法–關(guān)閉錯(cuò)誤訊息和啟動(dòng)視窗。然後,重新啟動(dòng)電腦。再次從頭開(kāi)始重試Windows啟動(dòng)程序。修復(fù)1–從終端啟動(dòng)從cmd終端啟動(dòng)WindowsServerEdition系統(tǒng)。階段–1檢查Windows伺服器版本您必須檢查您使用的是哪種類型的W
