天天看點

php中的cookie

PHP中的cookie
2004-05-22    builder.com   

列印自: 西交天空

位址: http://www.xjtusky.com/article/article.php/375

PHP中的cookie

用PHP來設定并讀取cookie是一件極其——我們敢說嗎?——簡單的事情。我們并不希望大力鼓吹cookie,不過它們的确既重要又實用。它們是解決某些問題時唯一适用的工具。

要建立并修改一個 cookie,可使用PHP函數setcookie()。取決于想對cookie進行控制的程度,及誰可以讀取cookie的值,setcookie()最多可有六個參數。

設定cookie最簡單的方式如下:

setcookie('name', 'bret');

然後,在使用者退出前,接下來使用此浏覽器檢視的站點中每一個頁面,都會有一個值為“bret”的變量$name,并且很容易通過PHP 對其進行通路。由于其生存期是一次使用者連結,此類cookie被稱為session cookie,。

如果希望使用者關閉其浏覽器後,仍保留此cookie,則必須傳遞第三個參數給setcookie()函數,即設定此cookie的有效日期。由于PHP的背景完全源于Unix的思想,這個有效期限需要以從1970年1月1日起算的總秒數來代表。如果作為Unix程式員,這種算法對你而言可能是合情合理的。但如果來自Windows或Macintosh陣營,你可能隻能搖頭歎息,無法了解那些古怪的Unix家夥們。

不過無需害怕。PHP提供一個很好用的函數mktime()。你隻要按順序傳送給mktime()你希望表示的小時,分鐘,秒數,月份,日期,及年份,mktime()就會傳回該日期自1970年1月1日的總秒數。是以,如果需要模拟 Y2K 問題:

<?php

$y2k = mktime(0,0,0,1,1,2000);

setcookie('name', 'bret', $y2k);

?>

現在,你的cookie将會在2000年失效。

如果需要更新cookie以讓其儲存新值,隻需要将其原值覆寫即可。是以,即使你已經在之前的頁面中剛剛發送cookie,仍可以将你的名字改為“jeff”。

<?php

$y2k = mktime(0,0,0,1,1,2000);

setcookie('name', 'jeff', $y2k);

?>

注意這樣做并不會改變變量$name的值。在頁面載入的時候,其值就已經确定。如果希望總是同時确定二者,可以編寫如下代碼:

<?php

$name = 'jeff';

$y2k = mktime(0,0,0,1,1,2000);

setcookie('name', $name, $y2k);

?>

setcookie()的下兩個參數可以控制讀取cookie的程式的域及目錄路徑。預設設定為僅在與送出cookie的伺服器相同且在同級或以下的目錄結構内的頁面才可以讀取其值。這是出于網絡安全方面的考慮。然而,如果你有一個帳号“www.domain.com”但同時也是“other.domain.com”,且帳戶允許從~/myhome目錄處理頁面,則應更改setcookie()如下:

<?php

setcookie('name', 'jeff', $y2k, '~/myhome', '.domain.com');

?>

我們還未使用過的setcookie()最後一個參數是設定cookie隻傳送給實行諸如SSL的安全連接配接的Web伺服器。要使用此功能,将第六個值設定為1。

删除cookie非常簡單,僅需簡單地将cookie的名傳送給setcookie(),PHP就會将其删除掉。

<?php setcookie('name'); ?>

最後還有一個關于使用cookie的重要事項。由于cookie與HTTP的特定工作方式,你必須在你輸出任何文本前,傳送出所有的cookie。否則PHP會給出警告,并且cookie也不會被傳送。是以,這樣做是正确的方法:

<?php

setcookie('name', 'jeff');

echo "Hello Everyone!";

?>

以下是錯誤地:

<?php

echo "Hello Everyone!";

setcookie('name', 'jeff');

?>

David Sklar是Student.Net Publishing的首席資訊官。

Adam Trachtenberg是Student.Net Publishing産品副主管。