1、Cookie和Session簡介與區別
在非常多時候,我們需要跟蹤瀏覽者在整個網站的活動,對他們身份進行自動或半自動的識別(也就是平時常說的網站登陸之類的功能),這時候,我們常採用Cookie與 Session來跟蹤和判斷。
區別
Session信息是存放在server端,但sessionid是存放在client cookie的,當然php的session存放方法是多樣化的,這樣就算禁用cookie一樣可以跟蹤Cookie是完全保持在客戶端的如:IE firefox當客戶端禁止cookie時將不能再使用
2、Cookie的配置與應用
Setcookie(stringname,stringvalue,int expire,string path, string domain, int secure);
其中name是cookie變量名稱標識,你在php中將能象使用普通變量名相同來用他引用cookie變量。value是cookie變量的初始值,expire表示該cookie變量的有效時間;path 爲該cookie變量的相關路徑;domain表示cookie變量的網站;secure則需在 https的安全傳輸時纔有效。
SetCookie("Cookie","cookievalue",time()+3600, "/forum",".php100.com", 1);
接收和處理Cookie
PHP對Cookie的接收和處理的支持非常好,是完全自動的,跟FORM變量的原則一樣,特別簡單。
比如設置一個名爲MyCookier的Cookie,PHP會自動從WEB服務器接收的HTTP頭裏把它分析出來,並形成一個與普通變量一樣的變量,名爲$myCookie,這個變量的值就是Cookie的值。數組同樣適用。另外一個辦法是引用PHP的全局變量$HTTP_COOKIE_VARS數組。
分別舉例如下:(假設這些都在以前的頁面裏設置過了,並且仍然有效)
echo$MyCookie;
echo$CookieArray[0];
echo$_COOKIE["MyCookie"]; //目前最常用的方式
echo$HTTP_COOKIE_VARS["MyCookie"];
刪除Cookie
要刪除一個已經存在的Cookie,有兩個辦法:
1、SetCookie("Cookie","");//把Cookie設置爲空
2、SetCookie("Cookie","value" , time()-1 / time() );//設置Cookie超時
使用Cookie的限制
1、必須在HTML文件的內容輸出之前設置;
2、不同的瀏覽器對Cookie的處理不一致,且有時會出現錯誤的結果。
3、限制是在客戶端的。一個瀏覽器能創建的Cookie數量最多爲30個,並且每個不能超過4KB,每個WEB站點能設置的Cookie總數不能超過20個。
3、Session的配置與應用
session_start(); //初始化session.需在文件頭部
$_SESSION[name]=value; //配置Seeeion
echo$_SESSION[name]; //使用session
isset($_SESSION[name]); // 判斷
unset($_SESSION[name]); //刪除
session_destroy(); //消耗所有session
注意:session_register(),session_unregister,session_is_registered在php5下不再使用
COOKIE實例
<?php
if($_POST[name] && $_POST[pass]){
setcookie('id',$_POST[name]);
setcookie('pass',$_POST[pass]);
echo "<script>location.href='login.php'</script>";
}
if($_COOKIE[id] && $_COOKIE[pass]){
echo "登錄成功".$_COOKIE[id];
echo "密碼:".$_COOKIE[pass];
}
?>
<form action="" method="post">
用戶名:
<input type="text" name="name" /><br><br>
密 碼:
<input type="password" name="pass"/><br>
<input type="submit" value="login"/>
</form>