很多時候,我們需要跟蹤浏覽者在整個網站的活動,對他們身份進行自動或半自動的識別(也就是平時常說的網站登陸之類的功能),這時候,我們常采用Cookie與 Session來跟蹤和判斷。
Session信息是存放在server端,但session id是存放在client cookie的,當然php的session存放方法是多樣化的,這樣就算禁用cookie一樣可以跟蹤。
Cookie是一種在遠程浏覽器端存儲數據並以此來跟蹤和識別用戶的機制。Cookie是完全保持在客戶端的如:IE firefox 當客戶端禁止cookie時將不能再使用。
Setcookie(string name, string value, 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, "/librarys", ".bkjia.com", 1);
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"];
2. 刪除Cookie
要刪除一個已經存在的Cookie,有兩個辦法:
3. 使用Cookie的限制
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下不再使用。
cookies用法實例:
if($_GET['out']) { //用於注銷cookies setcookie('id',""); setcookie('pass',""); echo "<script>location.href='login.php'</script>"; //因為cookies不是及時生效的,只有你再次刷新時才生效,所以,注銷後讓頁面自動刷新。 } if($_POST['name']&&$_POST['password']) //如果變量用戶名和密碼存在時,在下面設置cookies { //用於設置cookies setcookie('id',$_POST['name'],time()+3600); setcookie('pass',$_POST['password'],time()+3600); echo "<script>location.href='login.php'</script>"; //讓cookies及時生效 } if($_COOKIE['id']&&$_COOKIE['pass']) { //cookies設置成功後,用於顯示cookies echo "登錄成功!<br />用戶名:".$_COOKIE['id']."<br/>密碼:".$_COOKIE['pass']; echo "<br />"; echo "<a href='login.php?out=out'>注銷cookies</a>"; //雙引號內,如果再有引號,需要用單引號。 } ?> <form action="" method="post"> 用戶ID: <input type="text" name="name" /><br/><br/> 密碼: <input type="password" name="password" /><br/><br /> <input type="submit" name="submit"> </form>
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>"; } ?> <form action="login.php" method="post"> 用戶ID: <input type="text" name="name" /><br/><br/> 密碼: <input type="password" name="password" /><br/><br /> <input type="submit" name="submit"> </form>