|
先舉個cookies應(yīng)用的例子:當(dāng)我連接到Amazon.com時,瀏覽器在接受第一個頁面之前會把它以前設(shè)置的cookies的內(nèi)容傳送給Amazon。然后Amazon.com對傳送過來的內(nèi)容加以檢查,看看在數(shù)據(jù)庫中有沒有相關(guān)資料,在匹配之后,在為我建立一個定制的頁面?zhèn)魉偷竭^來。
為cookies賦值
必須在服務(wù)器傳送任何內(nèi)容給客戶瀏覽器之前為Cookies賦值。要做到這一點,cookies的設(shè)置就必須放在<HEAD>標(biāo)簽內(nèi):
<?php
setcookie("CookieID",$USERID);
?>
<HTML>
<BODY>
</BODY>
</HTML>
setcookie函數(shù)一共有六個參數(shù),用逗號來分隔:
cookie的名稱,是一個字符串,例如:"CookieID"。其間不允許有冒號,逗號和空格。這個參數(shù)是必須的,而其它的所有參數(shù)都是可選的。如果只有這一個參數(shù)被給出,那么這個cookie將被刪除。
cookie的值,通常是一個字符串變量,例如:$USERID。也可以為它賦一個??來略過值的設(shè)置。
cookie失效的時間。如果被省略(或者被賦值為零),cookie將在這個對話期(session)結(jié)束后失效。這個參數(shù)可以是一個絕對的時間,用DD-Mon-YYHH:MM:SS來表示,比如:"24-Nov-9908:26:00"。而更常用的是設(shè)置一個相對時間。這是通過time()函數(shù)或者mktime函數(shù)來實現(xiàn)的。比如time()+3600將使得cookie在一個小時后失效。
一個路徑,用來匹配cookie的。當(dāng)在一個服務(wù)器上有多個同名的cookie的設(shè)置,為避免混淆,就要用到這個參數(shù)了。使用"/"路徑的和省略這個參數(shù)的效果是一樣的。要注意的是NETscape的cookie定義是把域名放在路徑的前面的,而php則與之相反。
服務(wù)器的域名,也是用來匹配cookie的。要注意的是:在服務(wù)器的域名前必須放上一個點(.)。例如:".friendshipcenter.com"。因為除非有兩個以上的點存在,否者這個參數(shù)是不能被接受的。
cookie的安全級,是一個整數(shù)。1表示這個cookie只能通過“安全”的網(wǎng)絡(luò)來傳送。0或者省略則表示任何類型的網(wǎng)絡(luò)都可以。
Cookies和變量
當(dāng)php腳本從客戶瀏覽器提取了一個cookie后,它將自動的把它轉(zhuǎn)換成一個變量。例如:一個名為CookieID的cookie將變成變量$CookieID.
Cookies的內(nèi)容被報存在HTTP_COOKIE_VARS數(shù)組中,你還可以通過這個數(shù)組和cookie的名稱來存取指定的cookie值:
print$HTTP_COOKIE_VARS[CookieID];
記住每一個用戶
回過頭在來看看上面的submitform.php3文件,它的作用是把客戶的姓名添加到數(shù)據(jù)庫中,現(xiàn)在我想為它添加一些東西。我想為每個用戶都分配一個唯一的用戶標(biāo)志,然后把這個標(biāo)志放在Cookies中,這樣每當(dāng)用戶訪問我的網(wǎng)站的時候,通過cookie和其中的用戶標(biāo)志,我就能夠知道他是誰了。
MySQL能夠被設(shè)置成為每一個新的紀(jì)錄自動的分配一個數(shù)字,這個數(shù)字從1開始,以后每次自動加1。用一行SQL語句,你就可以輕松的為數(shù)據(jù)表添加這樣的一個字段,我把它叫做USERID:
ALTERTABLEdbname
ADDCOLUMN
USERIDINT(11)NOTNULL
PRIMARYKEYAUTO_INCREMENT;
對這個字段我們作了一些特別的設(shè)置。首先,通過“INT(11)”定義它的類型為11位的整數(shù);然后用“NOTNULL”關(guān)鍵字讓這個字段的值不能為NULL;再用“PRIMARYKEY”把它設(shè)置為索引字段,這樣搜索起來就會更快;最后,“AUTO_INCREMENT”定義它為自動增一的字段。
當(dāng)把用戶的姓名插入到數(shù)據(jù)庫后,就應(yīng)該在他們的瀏覽器上設(shè)置cookie了。這時利用的就是剛才我們談到的USERID字段的值:
<?php
mysql_connect(localhost,username,password);
mysql_select_db(dbname);
mysql_query("INSERTINTOtablename(first_name,last_name)
VALUES('$first_name','$last_name')
");
setcookie("CookieID",
mysql_insert_id(),
time()+94608000,
"/");/*三年后cookie才會失效*/
?>
php函數(shù)mysql_insert_id()返回在最后一次執(zhí)行了INSERT查詢后,由AUTO_INCREMENT定義的字段的值。這樣,只要你不清除掉瀏覽器的Cookies,網(wǎng)站就會永遠(yuǎn)“記住”你了
讀取cookie
我們來寫一個像Amazon.com所作的那樣的腳本。首先,php腳本會先檢查客戶瀏覽器是否發(fā)送了cookie過來,如果是那樣的話,用戶的姓名就會被顯示出來。如果沒找到cookie的話,就顯示一個表單,讓客戶登記他們的姓名,然后把他添加到數(shù)據(jù)庫中,并在客戶瀏覽其中設(shè)置好cookie。
首先,先來顯示cookie的內(nèi)容:
<?php
print$CookieID;
?>
然后,就可以把名字顯示出來了:
<?php
mysql_connect(localhost,username,password);
mysql_select_db(dbname);
$selectresult=mysql_query("SELECT*FROMtablename
WHEREUSERID='$CookieID'
");
$row=mysql_fetch_array($selectresult);
echo"歡迎你的光臨",$row[first_name],"!";
?>
就是這樣的了。我在其中沒有作判斷,交給你自己來完成好了
php技術(shù):用cookies來跟蹤識別用戶,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。