日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

(进阶篇)Cookie与 Session使用详解

發布時間:2025/4/5 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (进阶篇)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,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", ".learnphp.cn", 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" , time()-1 / time() );

使用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下不再使用

//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>

轉載于:https://www.cnblogs.com/zhangmiaomiao/p/6013178.html

總結

以上是生活随笔為你收集整理的(进阶篇)Cookie与 Session使用详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。