長沙發上的對話(三)

市場遊戲

  現在你已經知道瞭基本的東西,再來點復雜的吧,演示一個現實生活中的session 應用。讓我們假設一下,你有一個金融門戶,它允許它的用戶選擇四支股票,然後顯示每支股票的當前市場價格,並且在每一頁上顯示用戶在這個站點上的過程。

  在下面的例子中,我們假定用戶已經被驗證過身份並且登錄到站點上來瞭。我們使用瞭MySQL 數據庫,裡面有一個名為user_info的表,用於存儲用戶的四支股票和唯一用戶名。一旦一個session被初始化瞭,我們註冊變量保存用戶名和四支股票,然後同數據庫進行連接,取回值並顯示在頁面上。

  代碼如下:

$#@60;?php

//初始化一個session session_start();

//註冊session變量

//用戶名
session_register(username);

//選擇的股票變量
session_register(stock1);
session_register(stock2);
session_register(stock3);
session_register(stock4);

//連接MySQL
$db = mysql_connect(“someserver.com”, “tom”, “jones”);

//選擇數據庫
mysql_select_db(“stock_db”, $db);

//使用SQL查詢數據庫
$query = “select stock_pref1,stock_pref2,stock_pref3,stock_pref4
from user_info where username=$username”;

$result = mysql_query($query,$db);

//從數據庫中取股票代碼,並賦值給session變量
list($stock1,$stock2,$stock3,$stock4) = mysql_fetch_row($result);

echo “Hi $username!$#@60;br$#@62;”;
echo “Your selected stocks are:$#@60;br$#@62;”;
echo “$stock1$#@60;br$#@62;”;
echo “$stock2$#@60;br$#@62;”;
echo “$stock3$#@60;br$#@62;”;
echo “$stock4$#@60;br$#@62;”;

// code to generate rest of page

?$#@62;

  PHP4有許多與session相關的函數 — 大部分都不需要解釋,把他們列在下面。

session_destroy(): 釋放所有的session數據(當一個用戶從一個站點註銷時非常有用,你需要釋放掉在他訪問期間的所創建的所有變量)。

session_name():設置或讀取當前session的名字。

session_id():設置或讀取當前session的id值。 <BR
session_unregister(session_variable_name):從一個特別的session註銷一個變量。

session_is_registered():檢查是否一個session變量已經註冊瞭。

例如:

$#@60;?php

session_start();

if(session_is_registered(username))
{
echo “A session variable by the name “username”
already exists”;
}
else
{
echo “No variable named “username” registered yet.
Registering…”;
session_register(username);
}

?$#@62;

session_encode() and session_decode():將session數據編碼成字符串或將字符串解碼成session數據。

在這裡你可能使用他們:

$#@60;?php

session_start();

session_register(someString);
$someString=”I hate cats!”;

//將所有的session變量編成一個字符串
$sessStr = session_encode();

//可以在這裡看到
echo $sessStr;

echo “$#@60;br$#@62;$#@60;br$#@62;”;

//在出現cats的地方用dogs進行替換
$sessStr = ereg_replace(“cats”,”dogs”,$sessStr);

//解碼後更新瞭session變量
session_decode($sessStr);

//再顯示一次$sessstr
echo $someString;

?$#@62;

  最後,在開始PHPLIB之前,有一個技術性問題你應該知道的 — 上面所有的例子都使用瞭cookies在客戶端來保存session id值。但是如果用戶的瀏覽器被設成拒絕cookies會怎麼樣呢?

  如果發生這種情況,那就需要將一個session id通過嵌在url中從一頁傳遞到另一頁上去。例如: $#@60;a href=”http://www.someserver.com/admin/preferences.php3?PHPSESSID=$#@60;? echo “$PHPSESSID”; ?$#@62;”$#@62;Edit Your Portfolio! $#@60;/a$#@62;

  這個就可以保證在後面的頁面中session變量是有效的。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *