PHP使用者狀態(tài)管理技巧的應(yīng)用
發(fā)表時(shí)間:2024-01-27 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]使用者狀態(tài)管理(session support)是 PHP 4.0 一個(gè)讓大家期待已久的新功能。在 PHP 3.0 的時(shí)代,程序設(shè)計(jì)員必須使用其它人寫好的函式庫來實(shí)作狀態(tài)管理功能,或者就干脆放棄這項(xiàng)功能不用算了。而狀態(tài)管理功能的缺乏事實(shí)上是 PHP 3.0 最讓人感到失望的地方之一。不過現(xiàn)在狀況已...
使用者狀態(tài)管理(session support)是 PHP 4.0 一個(gè)讓大家期待已久的新功能。在 PHP 3.0 的時(shí)代,程序設(shè)計(jì)員必須使用其它人寫好的函式庫來實(shí)作狀態(tài)管理功能,或者就干脆放棄這項(xiàng)功能不用算了。而狀態(tài)管理功能的缺乏事實(shí)上是 PHP 3.0 最讓人感到失望的地方之一。不過現(xiàn)在狀況已經(jīng)得到改變,從 PHP 4.0 的早期測試版開始,使用者狀態(tài)管理便已經(jīng)成為 PHP 內(nèi)建的功能之一了。
你可以使用狀態(tài)管理功能來管理使用者從進(jìn)入網(wǎng)站開始一直到離開網(wǎng)站為止這段期間內(nèi)的所有相關(guān)變量(只要使用者沒有離開網(wǎng)站,那么這些變量就都可以取用,不會因?yàn)槭褂谜唠x開某個(gè)單一頁面而造成資料消失),而不需要儲存許多cookie 或者使用隱藏窗體字段,甚至將這些變量儲存在數(shù)據(jù)庫里面,造成數(shù)據(jù)庫服務(wù)器的大量負(fù)荷。
一旦你在網(wǎng)站中的某一頁激活狀態(tài)管理,PHP 引擎便會開始紀(jì)錄使用者狀態(tài)(如果對這個(gè)使用者來說系統(tǒng)還沒開始紀(jì)錄該訪問者的狀態(tài)的話),或者繼續(xù)紀(jì)錄某個(gè)先前已經(jīng)激活的使用者狀態(tài)。要激活 PHP 的狀態(tài)管理功能,你可以使用下面這個(gè)語法:
session_start();
一旦激活狀態(tài)管理,PHP 會通過 cookie 傳送一個(gè)獨(dú)一無二的狀態(tài)代碼(這個(gè)代碼看起來會像是:940f8b05a40d5119c030c9c7745aead9)給使用者,同時(shí)在服務(wù)器這端,PHP 引擎會自動產(chǎn)生一個(gè)檔名與狀態(tài)代碼相對應(yīng)的暫存文本文件(如:sess_940f8b05a40d5119c030c9c7745aead9),該檔案會用來儲存程序設(shè)計(jì)員在這個(gè)使用者狀態(tài)紀(jì)錄中所注冊的所有變量。
談到使用者狀態(tài)管理,最常使用的例子便是一個(gè)頁面存取計(jì)數(shù)器(access counter)了:現(xiàn)在我就開始教大家撰寫 PHP 程序代碼。
特別注意
在你嘗試激活使用者狀態(tài)紀(jì)錄之前,千萬不能夠輸出任何內(nèi)容(不能有空格,TAB 甚至換行等等空格符,也不能有任何 HTML 卷標(biāo),任何內(nèi)容都不行)給瀏覽器。這是因?yàn)闋顟B(tài)管理相關(guān)函數(shù)會送出 HTTP 表頭(header)信息給瀏覽器,如果在送出 HTTP 表頭信息給瀏覽器之前已經(jīng)有其它內(nèi)容被輸出的話,系統(tǒng)將會出現(xiàn)錯(cuò)誤訊息。
如果該使用者的狀態(tài)管理尚未被激活的話,下面這行程序便會激活該使用者的狀態(tài)管理:
session_start();
接下來,注冊一個(gè)名為count的變量:
session_register('count');
一旦你注冊了一個(gè)變量,PHP 便會在從使用者進(jìn)入網(wǎng)站一直到離開網(wǎng)站的整個(gè)瀏覽過程中自動替你維護(hù)這個(gè)變量的值,你可以隨時(shí)取用這些注冊過的變量。剛注冊好的變量并沒有指定任何值給它,不過一旦我們增加 count 變量的值,它的值便會是 1 了:
$count++;
把這些程序代碼組合起來,我們的程序代碼就會做下面這些事情了:激活使用者狀態(tài)紀(jì)錄功能(如果對該使用者而言尚未激活的話),指定一個(gè)獨(dú)一無二的狀態(tài)代碼(session id)給該使用者,注冊一個(gè)名為 count 的變量,并且在每次使用者瀏覽到該頁面的時(shí)候,將變量 $count 的值加一,這個(gè)值就可以用來記錄該使用者瀏覽過該頁面的次數(shù)了。
如果要將使用者這次的瀏覽歷程中觀看了該頁面多少次,我們只需要將變量$count 的值列印出來就行了:
echo "<P>您已經(jīng)瀏覽這個(gè)頁面$count 次了。</p>";
完整的頁面瀏覽計(jì)數(shù)器程序代碼看起來就像這樣:
<?session_start();
session_register('count');
$count++;
echo "<P>您已經(jīng)瀏覽這個(gè)頁面 $count 次了。</p>";
?>
如果你不斷重新加載這個(gè)頁面,你會發(fā)現(xiàn)畫面上顯示的瀏覽次數(shù)會不斷的增加。除了注冊單純的變量以外,我們也可以注冊一個(gè)數(shù)組(array)到使用者狀態(tài)紀(jì)錄中。假設(shè)我們有下面這個(gè)名為 $faves 的數(shù)組:
$faves = array ('古典音樂','旅游','唱歌','Linux');
注冊數(shù)組的做法和注冊其它單純變量是完全一樣的:
session_register('faves');
注冊完成數(shù)組以后,在往后的程序代碼里面要參照到該數(shù)組的做法也沒有任何不同,只要單純地叫用 $faves 這個(gè)變量就行了。假設(shè)你的使用者在網(wǎng)站中某個(gè)頁面窗體里頭選擇了一些他所喜歡的東西,而且你將這些項(xiàng)目通過 $faves 數(shù)組注冊到該使用者的狀態(tài)紀(jì)錄里面,那么在網(wǎng)站中其它頁面你可以很容易地把這些項(xiàng)目顯示在畫面上:
<?
session_start();
echo "我的訪客喜歡的東西是:<ul>";
while (list($v) = each ($faves)) {
echo "<li>$v</li>"; }
echo "</ul>";
?>
就這么輕輕松松的,你就可以把訪客喜歡的東西顯示在網(wǎng)頁上了。
使用者狀態(tài)紀(jì)錄所注冊的變量是無法用查詢字符串(query string)來蓋過的,比方說,使用者無法直接在瀏覽器的地址列輸入下面的 URL:
http:///www.yourdomain.com/yourscript.php?count=56 來企圖蓋過原本注冊在使用者狀態(tài)紀(jì)錄中的 $count 變量的值。這是一個(gè)非常重要的安全觀念:只有你自己能夠在你的程序里面注冊或者刪除使用者狀態(tài)紀(jì)錄中的變量,其它使用者無法通過 URL 后面的查詢字符串企圖混淆這些變量的值。
要刪除原本注冊過的使用者狀態(tài)變量,你可以使用下面的語法:
session_unregister('count');
要將整個(gè)使用者狀態(tài)紀(jì)錄變量全部刪除并且停止紀(jì)錄,請使用下面的語法:
session_destroy();
結(jié)語:
適當(dāng)?shù)厣朴檬褂谜郀顟B(tài)紀(jì)錄功能的好處多多:它可以讓我們不須將使用者狀態(tài)資料儲存在數(shù)據(jù)庫中,減少數(shù)據(jù)庫服務(wù)器的負(fù)荷。它也可以讓我們不需要自己撰寫長長的程序代碼來通過 cookie 紀(jì)錄這些使用者狀態(tài)變量(而且,這樣一來我們也不用在網(wǎng)站的隱私權(quán)聲明里頭花上很長的篇幅來解釋為什么當(dāng)使用者登入網(wǎng)站的時(shí)候,我們要儲存五十個(gè) cookie 到他們的硬盤里面去了)。這項(xiàng)功能讓我們只需要一個(gè) cookie 來儲存一個(gè)變量(session id)就行了,其它所有的信息都通過一個(gè)精巧無比的機(jī)制來幫我們紀(jì)錄,讓我們的工作變得再簡單不過了!