PHP中的cookie與session使用詳細介紹

高洛峰
發布: 2023-03-06 20:30:02
原創
1706 人瀏覽過

非常多時候,我們需要追蹤瀏覽者在整個網站的活動,對他們身份進行自動或半自動的識別(也就是平時常說的網站登陸之類的功能),這時候,我們常採用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 的安全傳輸時才有效。

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","");

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.

#if($_GET['out'])

{   //用於註銷cookies

    setcookie('id',"");

    setcookie('pass',""ookie);

    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'"; //讓cookies及時生效
}
if($_COOKIE['id']&&$_COOKIE['pass'])
{   //cookies設定成功後,用於顯示cookies
    echo "登入成功!
使用者名稱:".$_COOKIE['id']."
密碼: ".$_COOKIE['pass'];
    echo "
";
    echo "註銷cookies ";  //雙引號內,如果再有引號,需要用單引號。
}

?>


用戶ID:



密碼:




session用法實例

<?php
//session用法实例
session_start();//启动session,必须放在第一句,否则会出错。
if($_GET[&#39;out&#39;])
{
     
    unset($_SESSION[&#39;id&#39;]);
    unset($_SESSION[&#39;pass&#39;]);
}
if($_POST[&#39;name&#39;]&&$_POST[&#39;password&#39;])
{   
   //用于设置session
    $_SESSION[&#39;id&#39;]=$_POST[&#39;name&#39;];
    $_SESSION[&#39;pass&#39;]=$_POST[&#39;password&#39;];
}
if($_SESSION[&#39;id&#39;]&&$_SESSION[&#39;pass&#39;])
{
    echo "登录成功!<br/>用户ID:".$_SESSION[&#39;id&#39;]."<br />用户密码:".$_SESSION[&#39;pass&#39;];
    echo "<br />";
    echo "<a href=&#39;login.php?out=out&#39;>注销session</a>";
}

?>
登入後複製

#


使用者ID:



密碼:





以上是PHP中的cookie與session使用詳細介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!