用PHP來設定並讀取cookie是一件極其——我們敢說嗎? ——簡單的事。我們不希望大力鼓吹cookie,不過它們的確既重要又實用。它們是解決某些問題時唯一適用的工具。
要建立並修改一個 cookie,可使用PHP函數setcookie()。取決於想控制cookie的程度,及誰可以讀取cookie的值,setcookie()最多可有六個參數。
設定cookie最簡單的方式如下:
<?php 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 $today = mktime(12,0,0,6,25,1999); echo 'Here it is '.date('g:i:s a, F d, Y',$today); echo ''; echo 'In GMT it is '.gmdate('g:i:s a, F d, Y',$today); ?>
以上是php 中的cookie使用說明的詳細內容。更多資訊請關注PHP中文網其他相關文章!