淺談PHP Cookie處理函數(shù)
(o゜▽゜)o☆[BINGO!]
ok,我們先看看cookie是什么東東?
cookie是服務(wù)器留在客戶端的用于識(shí)別用戶或者存儲(chǔ)一些數(shù)據(jù)的小文件(注意,session存儲(chǔ)在服務(wù)器端,這是兩者的區(qū)別之一)。我們平時(shí)登錄某門戶時(shí),會(huì)有選項(xiàng)“是否保存登錄”或者“下次自動(dòng)登錄”,當(dāng)我們勾選了之后,服務(wù)器就會(huì)在我們的瀏覽器創(chuàng)建cookie文件來保存我們的信息。每當(dāng)計(jì)算機(jī)通過瀏覽器請(qǐng)求頁面時(shí),它會(huì)同時(shí)發(fā)送cookie。通過PHP,可以創(chuàng)建并取回cookie的值。cookie在web中是很重要的角色,早在網(wǎng)景瀏覽器的時(shí)候就產(chǎn)生了cookie。cookie經(jīng)常被用于用戶驗(yàn)證系統(tǒng)。
1.創(chuàng)建cookie
函數(shù)setcookie()可以在PHP中生成cookie。由于cookie是HTTP頭標(biāo)部分的內(nèi)容,因此必須在輸出任何數(shù)據(jù)之前調(diào)用setcookie(),這個(gè)限制和header()類似,定義:
bool setcookie( string name[,string value][,int expire][,string path][,string domain][,bool secure][,bool httponly])
好多參數(shù)??!Σ(⊙▽⊙"a 不急,讓我們看看各個(gè)參數(shù)的作用:
name : 必選,表示cookie的名字。
value : 可選,表示cookie值,存儲(chǔ)在客戶端,當(dāng)為空時(shí),表示撤銷客戶端中該cookie的資料(這樣可以刪除cookie)。
expire : 可選,表示cookie的有效截止時(shí)間,也就是過期時(shí)間,如果沒有指定或者指定為0,那么通常是在關(guān)閉瀏覽器時(shí)失效。
path : 可選,cookie有效路徑。
domain : 可選,cookie有效域名。
secure : 表示在HTTPS的安全傳輸時(shí)才有效。
實(shí)例(建立一個(gè)名字為test,值為China的cookie):
<?php setcookie("test",China"); ?>
使用setcookie()給的值只能是數(shù)字或者字符串,不能是其他的復(fù)雜結(jié)構(gòu)。
2.獲取cookie
創(chuàng)建cookie后,就可以使用預(yù)定義變量$_COOKIE來獲取cookie。不過,只能在其他頁面獲取cookie,因?yàn)樵趐hp中,被設(shè)置的cookie不會(huì)在本頁面生效,除非該頁面被刷新。
實(shí)例:
<?php setcookie("test","China"); echo "cookie is ".$_COOKIE["test"]; ?>
這里之所以要刷新頁面,是因?yàn)閏ookie的值不會(huì)在調(diào)用setcookie()之后立即存儲(chǔ)在_COOKIE中。
3.cookie的有效期
cookie有生命周期,也就是cookie存在的有效時(shí)間??梢栽O(shè)置第三個(gè)參數(shù)來設(shè)置有效時(shí)間。
實(shí)例(設(shè)置cookie有效時(shí)間的幾種方式):
setcookie("cookie_one","A",time()+60*60); //cookie在一小時(shí)后失效 setcookie("cookie_two","B",time()+60*60*24); //cookie在一天后失效 setcookie("cookie_three","C",mktime(23,53,19,10,09,2020)); //cookie在2020年10月9日23時(shí)53分19秒失效 setcookie("cookie_four","D"); //關(guān)閉瀏覽器后cookie失效
4.cookie的有效路徑
cookie中的路徑用來控制設(shè)置的cookie在哪個(gè)路徑下有效,默認(rèn)為'/',在所有路徑下都有效,也就是在整個(gè)服務(wù)器域名下都有效,當(dāng)設(shè)定了其他路徑之后,則只在設(shè)定的路徑以及子路徑下有效,例如:
setcookie('test', time(), 0, '/path');
上面的設(shè)置會(huì)使test在/path以及子路徑/path/abc下都有效,但是在根目錄下就讀取不到test的cookie值。
一般情況下,大多是使用所有路徑的,只有在極少數(shù)有特殊需求的時(shí)候,會(huì)設(shè)置路徑,這種情況下只在指定的路徑中才會(huì)傳遞cookie值,可以節(jié)省數(shù)據(jù)的傳輸,增強(qiáng)安全性以及提高性能。
5.刪除cookie
刪除cookie比較簡(jiǎn)單,也是通過setcookie()來實(shí)現(xiàn)的(不要使用unset()!!!)下面的代碼就是個(gè)簡(jiǎn)單例子:
setcookie("test","");
通過將第二個(gè)參數(shù)設(shè)為空來達(dá)到刪除cookie的目的。如果設(shè)置cookie時(shí),為cookie提供了特定的值,那么在刪除cookie時(shí),仍然需要提供這些參數(shù),以便PHP可以正確地刪除cookie。
以上這篇淺談PHP Cookie處理函數(shù)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
php 如何禁用eval() 函數(shù)實(shí)例詳解
在php中eval是一個(gè)函數(shù)并且不能直接禁用了,但eval函數(shù)又相當(dāng)?shù)奈kU(xiǎn)并經(jīng)常會(huì)出現(xiàn)一些問題,今天我們就一起來看看eval函數(shù)對(duì)數(shù)組的操作及php 如何禁用eval() 函數(shù),需要的朋友可以參考下2016-12-12destoon網(wǎng)站轉(zhuǎn)移服務(wù)器后搜索漢字出現(xiàn)亂碼的解決方法
這篇文章主要介紹了destoon網(wǎng)站轉(zhuǎn)移服務(wù)器后搜索漢字出現(xiàn)亂碼的解決方法,非常實(shí)用,需要的朋友可以參考下2014-06-06Laravel5.1 框架控制器基礎(chǔ)用法實(shí)例分析
這篇文章主要介紹了Laravel5.1 框架控制器基礎(chǔ)用法,結(jié)合實(shí)例形式分析了laravel5.1框架控制器的基本原理、定義與使用方法,需要的朋友可以參考下2020-01-01CodeIgniter安全相關(guān)設(shè)置匯總
這篇文章主要介紹了CodeIgniter安全相關(guān)設(shè)置,需要的朋友可以參考下2014-07-07使用PHP Socket 編程模擬Http post和get請(qǐng)求
這篇文章主要介紹了使用PHP Socket 編程模擬Http post和get請(qǐng)求 ,需要的朋友可以參考下2014-11-11遍歷echsop的region表形成緩存的程序?qū)嵗a
下面小編就為大家?guī)硪黄闅vechsop的region表形成緩存的程序?qū)嵗a。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11