|
要創(chuàng)建并修改一個 cookie,可使用php函數(shù)setcookie()。取決于想對cookie進行控制的程度,及誰可以讀取cookie的值,setcookie()最多可有六個參數(shù)。
設(shè)置cookie最簡單的方式如下:
<?php
setcookie('name', 'bret');
?>
然后,在用戶退出前,接下來使用此瀏覽器查看的站點中每一個頁面,都會有一個值為“bret”的變量$name,并且很容易通過php 對其進行訪問。由于其生存期是一次用戶連結(jié),此類cookie被稱為session cookie。
如果希望用戶關(guān)閉其瀏覽器后,仍保留此cookie,則必須傳遞第三個參數(shù)給setcookie()函數(shù),即設(shè)定此cookie的有效日期。由于php的背景完全源于Unix的思想,這個有效期限需要以從1970年1月1日起算的總秒數(shù)來代表。如果作為Unix程序員,這種算法對你而言可能是合情合理的。但如果來自Windows或Macintosh陣營,你可能只能搖頭嘆息,無法理解那些古怪的Unix家伙們。
不過無需害怕。php提供一個很好用的函數(shù)mktime()。你只要按順序傳送給mktime()你希望表示的小時,分鐘,秒數(shù),月份,日期,及年份,mktime()就會返回該日期自1970年1月1日的總秒數(shù)。因此,如果需要模擬 Y2K 問題:
<?php
$y2k = mktime(0,0,0,1,1,2000);
setcookie('name', 'bret', $y2k);
?>
現(xiàn)在,你的cookie將會在2000年失效。
如果需要更新cookie以讓其儲存新值,只需要將其原值覆蓋即可。因此,即使你已經(jīng)在之前的頁面中剛剛發(fā)送cookie,仍可以將你的名字改為“jeff”。
<?php
$y2k = mktime(0,0,0,1,1,2000);
setcookie('name', 'jeff', $y2k);
?>
注意這樣做并不會改變變量$name的值。在頁面載入的時候,其值就已經(jīng)確定。如果希望總是同時確定二者,可以編寫如下代碼:
<?php
$name = 'jeff';
$y2k = mktime(0,0,0,1,1,2000);
setcookie('name', $name, $y2k);
?>
setcookie()的下兩個參數(shù)可以控制讀取cookie的程序的域及目錄路徑。默認設(shè)定為僅在與送出cookie的服務(wù)器相同且在同級或以下的目錄結(jié)構(gòu)內(nèi)的頁面才可以讀取其值。這是出于網(wǎng)絡(luò)安全方面的考慮。然而,如果你有一個帳號“www.domain.com”但同時也是“other.domain.com”,且?guī)粼试S從~/myhome目錄處理頁面,則應(yīng)更改setcookie()如下:
<?php
setcookie('name', 'jeff', $y2k, '~/myhome', '.domain.com');
?>
我們還未使用過的setcookie()最后一個參數(shù)是設(shè)定cookie只傳送給實行諸如SSL的安全連接的Web服務(wù)器。要使用此功能,將第六個值設(shè)置為1。
刪除cookie非常簡單,僅需簡單地將cookie的名傳送給setcookie(),php就會將其刪除掉。
<?php
setcookie('name');
?>
最后還有一個關(guān)于使用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技術(shù):PHP中的cookie,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。