非常多時候,我們需要追蹤瀏覽者在整個網站的活動,對他們身份進行自動或半自動的識別(也就是平時常說的網站登陸之類的功能),這時候,我們常採用Cookie與Session來追蹤和判斷
1、Cookie和Session簡介與區別
在非常多時候,我們需要追蹤瀏覽者在整個網站的活動,對他們身份進行自動或半自動的識別(也就是平常常說的網站登陸之類的功能),這時候,我們常採用Cookie與Session來追蹤與判斷。
區別
Session資訊是存放在server端,但session id是存放在client cookie的,當然php的session存放方法是多樣化的,這樣就算禁用cookie一樣可以追蹤
Cookie是完全保持在客戶端的如:IE firefox 當客戶端禁止cookie時將無法再使用
2、Cookie的設定與應用
##Setcookie(string name, string value, int expire,stringpath, string domain, int secure);其中name是cookie變數名稱標識,你在php中將能像使用普通變數名稱相同來用他引用cookie變數。 value是cookie變數的初始值,expire表示該cookie變數的有效時間;path 為該cookie變數的相關路徑;domain 表示cookie變數的網站;secure 則需在 https 的安全傳輸時才有效。
接收與處理Cookie
PHP對Cookie的接收和處理的支援非常好,是完全自動的,跟FORM變數的原則一樣,特別簡單。
例如設定一個名為MyCookier的Cookie,PHP會自動從WEB伺服器接收的HTTP頭裡把它分析出來,並形成一個與普通變數一樣的變量,名為$ myCookie,這個變數的值就是Cookie的值。數組同樣適用。另外一個辦法是引用PHP的全域變數$HTTP_COOKIE_VARS陣列。
分別舉例如下:(假設這些都在先前的頁面裡設定過了,而且仍然有效)
echo $CookieArray[0];
echo $_COOKIE ["MyCookie"];
echo $HTTP_COOKIE_VARS["MyCookie"];
刪除Cookie
2、SetCookie("Cookie", "value","");
2、SetCookie("Cookie", "value" ,time()-1 / time() );
使用Cookie的限制
1、必須在HTML檔案的內容輸出之前設定;
2、不同的瀏覽器對Cookie的處理不一致,有時會出現錯誤的結果。
3、限制是在客戶端的。一個瀏覽器能創建的Cookie數量最多為30個,且每個不能超過4KB,每個WEB站點能設定的Cookie總數不能超過20個。
3、Session的設定與應用
##複製程式碼 程式碼如下:session_start(); $_SESSION[name]=value; //設定Seeeion
echo $_SESSION[name]; //使用session
isset($_SESSION[name]); // 判斷
unset($_SESSION[name ]); //刪除
session_destroy(); //上使用所有session
注意:session_register(),session_unfiister,session_is_registered#注意:session_register(),session_unister,session_is_registered#注意:session_register(),session_unister,session_is_registered#注意:session_register(),session#dregister,session_is_registered#注意:session_fp.
{ //用於註銷cookies
setcookie('id',"");setcookie('pass',""ookie);
echo "3f1c4e4b6b16bbbd69b2ee476dc4f83alocation.href='login.php'2cacc6d41bbb37262a98f745aa00fbf0";//因為cookies不是及時生效的,只有你再次刷新時才生效,所以,註銷後讓頁面自動刷新。}
if($_POST['name']&&$_POST['password']) //如果變數使用者名稱和密碼存在時,在下方設定cookies
{ //用於設定cookies
setcookie( 'id',$_POST['name'],time()+3600);
setcookie('pass',$_POST['password'],time()+3600);
echo"27835793f4768f4164d1421d99e293bclocation.href='login.php'2cacc6d41bbb37262a98f745aa00fbf0"; //讓cookies及時生效
}
if($_COOKIE['id']&&$_COOKIE['pass'])
{ //cookies設定成功後,用於顯示cookies
echo "登入成功!df250b2156c434f3390392d09b1c9563使用者名稱:".$_COOKIE['id']."076402276aae5dbec7f672f8f4e5cc81密碼: ".$_COOKIE['pass'];
echo "df250b2156c434f3390392d09b1c9563";
echo "288f918ddb251194273bb2bb7ced2db5註銷cookies5db79b134e9f6b82c0b36e0489ee08ed "; //雙引號內,如果再有引號,需要用單引號。
}
?>
157bbac558a7833eedb56b4dcc52ac44
用戶ID:
fbc453fe010a0e1073b27ef7fc8a76b9076402276aae5dbec7f672f8f4e5cc81076402276aae5dbec7f672f8f4e5cc81
密碼:
ce09dd6c711d83f754b570f95d40c9b3076402276aae5dbec7f672f8f4e5cc81df250b2156c434f3390392d09b1c9563
7c53702a2bf0be1eaf670e884b3f62e5
f5a47148e367a6035fd7a2faa965022e
session用法實例
<?php //session用法实例 session_start();//启动session,必须放在第一句,否则会出错。 if($_GET['out']) { unset($_SESSION['id']); unset($_SESSION['pass']); } if($_POST['name']&&$_POST['password']) { //用于设置session $_SESSION['id']=$_POST['name']; $_SESSION['pass']=$_POST['password']; } if($_SESSION['id']&&$_SESSION['pass']) { echo "登录成功!<br/>用户ID:".$_SESSION['id']."<br />用户密码:".$_SESSION['pass']; echo "<br />"; echo "<a href='login.php?out=out'>注销session</a>"; } ?>
#8c12f3b66c52e1f199625772d5b19830
使用者ID:
548052c193c31614ea2afa3f78d6e281076402276aae5dbec7f672f8f4e5cc81076402276aae5dbec7f672f8f4e5cc81
密碼:
ce09dd6c711d83f754b570f95d40c9b3076402276aae5dbec7f672f8f4e5cc81df250b2156c434f3390392d09b1c9563
d70b7f10a54717363b232a0501a6630a
f5a47148e367a6035fd7a2faa965022e
以上是PHP中的cookie與session使用詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!