用cookies來跟蹤識別用戶
發(fā)表時(shí)間:2024-01-19 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]讓我們來看看保存在瀏覽器中的內(nèi)容。如果你用的是IE5,在windows目錄下有一個(gè)cookies的目錄,里面有很多文本文件,文件名都是類似于wudong@15seconds[1].txt這樣的,這就是瀏覽器用來保存值的cookies了。在以前的IE版本中,cookies的內(nèi)容是可以察看的,但現(xiàn)在內(nèi)...
讓我們來看看保存在瀏覽器中的內(nèi)容。如果你用的是IE5,在windows目錄下有一個(gè)cookies的目錄,里面有很多文本文件,文件名都是類似于wudong@15seconds[1].txt這樣的,這就是瀏覽器用來保存值的cookies了。在以前的IE版本中,cookies的內(nèi)容是可以察看的,但現(xiàn)在內(nèi)容已經(jīng)被編碼了。在瀏覽器得到一個(gè)Web頁面之前,它會先看這個(gè)頁面的域名,是否在cookie中存在,如果有相比配的,瀏覽器會先把匹配的cookie傳送到服務(wù)器,然后才接受處理服務(wù)器傳送過來的頁面。
先舉個(gè)cookies應(yīng)用的例子:當(dāng)我連接到Amazon.com時(shí),瀏覽器在接受第一個(gè)頁面之前會把它以前設(shè)置的cookies的內(nèi)容傳送給Amazon。然后Amazon.com對傳送過來的內(nèi)容加以檢查,看看在數(shù)據(jù)庫中有沒有相關(guān)資料,在匹配之后,在為我建立一個(gè)定制的頁面?zhèn)魉偷竭^來。
為cookies賦值
必須在服務(wù)器傳送任何內(nèi)容給客戶瀏覽器之前為Cookies賦值。要做到這一點(diǎn),cookies的設(shè)置就必須放在<HEAD>標(biāo)簽內(nèi):
<?php
setcookie("CookieID",$USERID);
?>
<HTML>
<BODY>
</BODY>
</HTML>
setcookie函數(shù)一共有六個(gè)參數(shù),用逗號來分隔:
cookie的名稱,是一個(gè)字符串,例如:"CookieID"。其間不允許有冒號,逗號和空格。這個(gè)參數(shù)是必須的,而其它的所有參數(shù)都是可選的。如果只有這一個(gè)參數(shù)被給出,那么這個(gè)cookie將被刪除。
cookie的值,通常是一個(gè)字符串變量,例如:$USERID。也可以為它賦一個(gè)??來略過值的設(shè)置。
cookie失效的時(shí)間。如果被省略(或者被賦值為零),cookie將在這個(gè)對話期(session)結(jié)束后失效。這個(gè)參數(shù)可以是一個(gè)絕對的時(shí)間,用DD-Mon-YYHH:MM:SS來表示,比如:"24-Nov-9908:26:00"。而更常用的是設(shè)置一個(gè)相對時(shí)間。這是通過time()函數(shù)或者mktime函數(shù)來實(shí)現(xiàn)的。比如time()+3600將使得cookie在一個(gè)小時(shí)后失效。
一個(gè)路徑,用來匹配cookie的。當(dāng)在一個(gè)服務(wù)器上有多個(gè)同名的cookie的設(shè)置,為避免混淆,就要用到這個(gè)參數(shù)了。使用"/"路徑的和省略這個(gè)參數(shù)的效果是一樣的。要注意的是Netscape的cookie定義是把域名放在路徑的前面的,而PHP則與之相反。
服務(wù)器的域名,也是用來匹配cookie的。要注意的是:在服務(wù)器的域名前必須放上一個(gè)點(diǎn)(.)。例如:".friendshipcenter.com"。因?yàn)槌怯袃蓚(gè)以上的點(diǎn)存在,否者這個(gè)參數(shù)是不能被接受的。
cookie的安全級,是一個(gè)整數(shù)。1表示這個(gè)cookie只能通過“安全”的網(wǎng)絡(luò)來傳送。0或者省略則表示任何類型的網(wǎng)絡(luò)都可以。
Cookies和變量
當(dāng)PHP腳本從客戶瀏覽器提取了一個(gè)cookie后,它將自動的把它轉(zhuǎn)換成一個(gè)變量。例如:一個(gè)名為CookieID的cookie將變成變量$CookieID.
Cookies的內(nèi)容被報(bào)存在HTTP_COOKIE_VARS數(shù)組中,你還可以通過這個(gè)數(shù)組和cookie的名稱來存取指定的cookie值:
print$HTTP_COOKIE_VARS[CookieID];
記住每一個(gè)用戶
回過頭在來看看上面的submitform.php3文件,它的作用是把客戶的姓名添加到數(shù)據(jù)庫中,現(xiàn)在我想為它添加一些東西。我想為每個(gè)用戶都分配一個(gè)唯一的用戶標(biāo)志,然后把這個(gè)標(biāo)志放在Cookies中,這樣每當(dāng)用戶訪問我的網(wǎng)站的時(shí)候,通過cookie和其中的用戶標(biāo)志,我就能夠知道他是誰了。
MySQL能夠被設(shè)置成為每一個(gè)新的紀(jì)錄自動的分配一個(gè)數(shù)字,這個(gè)數(shù)字從1開始,以后每次自動加1。用一行SQL語句,你就可以輕松的為數(shù)據(jù)表添加這樣的一個(gè)字段,我把它叫做USERID:
ALTERTABLEdbname
ADDCOLUMN
USERIDINT(11)NOTNULL
PRIMARYKEYAUTO_INCREMENT;
對這個(gè)字段我們作了一些特別的設(shè)置。首先,通過“INT(11)”定義它的類型為11位的整數(shù);然后用“NOTNULL”關(guān)鍵字讓這個(gè)字段的值不能為NULL;再用“PRIMARYKEY”把它設(shè)置為索引字段,這樣搜索起來就會更快;最后,“AUTO_INCREMENT”定義它為自動增一的字段。
當(dāng)把用戶的姓名插入到數(shù)據(jù)庫后,就應(yīng)該在他們的瀏覽器上設(shè)置cookie了。這時(shí)利用的就是剛才我們談到的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
我們來寫一個(gè)像Amazon.com所作的那樣的腳本。首先,PHP腳本會先檢查客戶瀏覽器是否發(fā)送了cookie過來,如果是那樣的話,用戶的姓名就會被顯示出來。如果沒找到cookie的話,就顯示一個(gè)表單,讓客戶登記他們的姓名,然后把他添加到數(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],"!";
?>
就是這樣的了。我在其中沒有作判斷,交給你自己來完成好了