国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

PHP5中Cookie與 Session使用詳解

2024-05-04 23:07:45
字體:
供稿:網(wǎng)友

1、Cookie和Session簡(jiǎn)介與區(qū)別

在非常多時(shí)候,我們需要跟蹤瀏覽者在整個(gè)網(wǎng)站的活動(dòng),對(duì)他們身份進(jìn)行自動(dòng)或半自動(dòng)的識(shí)別(也就是平時(shí)常說的網(wǎng)站登陸之類的功能),這時(shí)候,我們常采用Cookie與 Session來跟蹤和判斷。

區(qū)別

Session信息是存放在server端,但session id是存放在client cookie的,當(dāng)然php的session存放方法是多樣化的,這樣就算禁用cookie一樣可以跟蹤

Cookie是完全保持在客戶端的如:IE firefox 當(dāng)客戶端禁止cookie時(shí)將不能再使用

2、Cookie的配置與應(yīng)用

Setcookie(string name, string value, int expire,string path, string domain, int secure);
其中name是cookie變量名稱標(biāo)識(shí),你在php中將能象使用普通變量名相同來用他引用cookie變量。value是cookie變量的初始值,expire 表示該cookie變量的有效時(shí)間;path 為該cookie變量的相關(guān)路徑;domain 表示cookie變量的網(wǎng)站;secure 則需在 https 的安全傳輸時(shí)才有效。

SetCookie("Cookie", "cookievalue",time()+3600, "/forum", ".php100.com", 1);
接收和處理Cookie
PHP對(duì)Cookie的接收和處理的支持非常好,是完全自動(dòng)的,跟FORM變量的原則一樣,特別簡(jiǎn)單。
比如設(shè)置一個(gè)名為 MyCookier的Cookie,PHP會(huì)自動(dòng)從WEB服務(wù)器接收的HTTP頭里把它分析出來,并形成一個(gè)與普通變量一樣的變量,名為$ myCookie,這個(gè)變量的值就是Cookie的值。數(shù)組同樣適用。另外一個(gè)辦法是引用PHP的全局變量$HTTP_COOKIE_VARS數(shù)組。
分別舉例如下:(假設(shè)這些都在以前的頁面里設(shè)置過了,并且仍然有效)

echo $MyCookie;
echo $CookieArray[0];
echo $_COOKIE["MyCookie"];
echo $HTTP_COOKIE_VARS["MyCookie"];
刪除Cookie

要?jiǎng)h除一個(gè)已經(jīng)存在的Cookie,有兩個(gè)辦法:

1、SetCookie("Cookie", "");
2、SetCookie("Cookie", "value" , time()-1 / time() );

使用Cookie的限制

1、必須在HTML文件的內(nèi)容輸出之前設(shè)置;
2、不同的瀏覽器對(duì)Cookie的處理不一致,且有時(shí)會(huì)出現(xiàn)錯(cuò)誤的結(jié)果。
3、限制是在客戶端的。一個(gè)瀏覽器能創(chuàng)建的Cookie數(shù)量最多為30個(gè),并且每個(gè)不能超過4KB,每個(gè)WEB站點(diǎn)能設(shè)置的Cookie總數(shù)不能超過20個(gè)。

3、Session的配置與應(yīng)用

復(fù)制代碼 代碼如下:


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用法實(shí)例

復(fù)制代碼 代碼如下:


if($_GET['out'])
{ //用于注銷cookies
setcookie('id',"");
setcookie('pass',"");
echo "<script>location.href='login.php'</script>"; //因?yàn)閏ookies不是及時(shí)生效的,只有你再次刷新時(shí)才生效,所以,注銷后讓頁面自動(dòng)刷新。
}

if($_POST['name']&&$_POST['password']) //如果變量用戶名和密碼存在時(shí),在下面設(shè)置cookies
{ //用于設(shè)置cookies
setcookie('id',$_POST['name'],time()+3600);
setcookie('pass',$_POST['password'],time()+3600);
echo "<script>location.href='login.php'</script>"; //讓cookies及時(shí)生效

}
if($_COOKIE['id']&&$_COOKIE['pass'])
{ //cookies設(shè)置成功后,用于顯示cookies
echo "登錄成功!<br />用戶名:".$_COOKIE['id']."<br/>密碼:".$_COOKIE['pass'];
echo "<br />";
echo "<a href='login.php?out=out'>注銷cookies</a>"; //雙引號(hào)內(nèi),如果再有引號(hào),需要用單引號(hào)。
}

?>
<form action="" method="post">
用戶ID:
<input type="text" /><br/><br/>
密碼:
<input type="password" /><br/><br />
<input type="submit">
</form>

//session用法實(shí)例

復(fù)制代碼 代碼如下:


<?php
//session用法實(shí)例
session_start();//啟動(dòng)session,必須放在第一句,否則會(huì)出錯(cuò)。
if($_GET['out'])
{

unset($_SESSION['id']);
unset($_SESSION['pass']);
}

if($_POST['name']&&$_POST['password'])
{
//用于設(shè)置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" /><br/><br/>
密碼:
<input type="password" /><br/><br />
<input type="submit">
</form>

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 柳州市| 咸丰县| 什邡市| 高尔夫| 乃东县| 临桂县| 化隆| 新密市| 南通市| 阜平县| 浦东新区| 绵阳市| 元氏县| 武功县| 平谷区| 庄浪县| 富民县| 徐闻县| 衡东县| 都昌县| 邵东县| 柳河县| 都江堰市| 武定县| 海城市| 若羌县| 京山县| 和顺县| 南漳县| 大新县| 商洛市| 丰城市| 白山市| 呼伦贝尔市| 青州市| 萝北县| 黎平县| 舟山市| 永仁县| 徐水县| 新密市|