PHP中cookie和session

PHP中cookie和session

1、總結

一、cookie

setcookie() 函數用於設置 cookiephp

註釋:setcookie() 函數必須位於 <html> 標籤以前html

1 <?php 2 $expire=time()+60*60*24*30; 3 setcookie("user", "runoob", $expire); 4 ?>
5 
6 <html>
7 .....

PHP 的 $_COOKIE 變量用於取回 cookie 的值。  echo $_COOKIE["user"];數據庫

刪除 cookie 時,您應當使過時日期變動爲過去的時間點。  setcookie("user", "", time()-3600);瀏覽器

 

 

二、session

在您把用戶信息存儲到 PHP session 中以前,首先必須啓動會話。服務器

註釋:session_start() 函數必須位於 <html> 標籤以前:cookie

存儲和取回 session 變量的正確方法是使用 PHP $_SESSION 變量:  $_SESSION['views']=1;session

若是您但願刪除某些 session 數據,可使用 unset() 或 session_destroy() 函數。 unset($_SESSION['views']);dom

 

 

2、cookie

PHP Cookie


cookie 經常使用於識別用戶。函數


Cookie 是什麼?

cookie 經常使用於識別用戶。cookie 是一種服務器留在用戶計算機上的小文件。每當同一臺計算機經過瀏覽器請求頁面時,這臺計算機將會發送 cookie。經過 PHP,您可以建立並取回 cookie 的值。post


如何建立 Cookie?

setcookie() 函數用於設置 cookie。

註釋:setcookie() 函數必須位於 <html> 標籤以前。

語法

setcookie(name, value, expire, path, domain);

實例 1

在下面的例子中,咱們將建立名爲 "user" 的 cookie,併爲它賦值 "runoob"。咱們也規定了此 cookie 在一小時後過時:

<?php setcookie("user", "runoob", time()+3600); ?> <html> .....

註釋:在發送 cookie 時,cookie 的值會自動進行 URL 編碼,在取回時進行自動解碼。(爲防止 URL 編碼,請使用 setrawcookie() 取而代之。)

實例 2

您還能夠經過另外一種方式設置 cookie 的過時時間。這也許比使用秒錶示的方式簡單。

<?php $expire=time()+60*60*24*30; setcookie("user", "runoob", $expire); ?> <html> .....

在上面的實例中,過時時間被設置爲一個月(60 秒 * 60 分 * 24 小時 * 30 天)。


如何取回 Cookie 的值?

PHP 的 $_COOKIE 變量用於取回 cookie 的值。

在下面的實例中,咱們取回了名爲 "user" 的 cookie 的值,並把它顯示在了頁面上:

<?php // 輸出 cookie 值 echo $_COOKIE["user"]; // 查看全部 cookie print_r($_COOKIE); ?>

在下面的實例中,咱們使用 isset() 函數來確認是否已設置了 cookie:

<html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> <?php if (isset($_COOKIE["user"]))     echo "歡迎 " . $_COOKIE["user"] . "!<br>"; else     echo "普通訪客!<br>"; ?> </body> </html>

 


如何刪除 Cookie?

當刪除 cookie 時,您應當使過時日期變動爲過去的時間點。

刪除的實例:

<?php // 設置 cookie 過時時間爲過去 1 小時 setcookie("user", "", time()-3600); ?>

 


若是瀏覽器不支持 Cookie 該怎麼辦?

若是您的應用程序須要與不支持 cookie 的瀏覽器打交道,那麼您不得不使用其餘的辦法在您的應用程序中的頁面之間傳遞信息。一種方式是經過表單傳遞數據(有關表單和用戶輸入的內容,在本教程的前面章節中咱們已經介紹過了)。

下面的表單在用戶單點擊 "Submit" 按鈕時,向 "welcome.php" 提交了用戶輸入:

<html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> <form action="welcome.php" method="post"> 名字: <input type="text" name="name"> 年齡: <input type="text" name="age"> <input type="submit"> </form> </body> </html>

取回 "welcome.php" 文件中的值,以下所示:

<html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> 歡迎 <?php echo $_POST["name"]; ?>.<br><?php echo $_POST["age"]; ?> 歲了。 </body> </html>

 

 

3、session

PHP Session


PHP session 變量用於存儲關於用戶會話(session)的信息,或者更改用戶會話(session)的設置。Session 變量存儲單一用戶的信息,而且對於應用程序中的全部頁面都是可用的。


PHP Session 變量

您在計算機上操做某個應用程序時,您打開它,作些更改,而後關閉它。這很像一次對話(Session)。計算機知道您是誰。它清楚您在什麼時候打開和關閉應用程序。然而,在因特網上問題出現了:因爲 HTTP 地址沒法保持狀態,Web 服務器並不知道您是誰以及您作了什麼。

PHP session 解決了這個問題,它經過在服務器上存儲用戶信息以便隨後使用(好比用戶名稱、購買商品等)。然而,會話信息是臨時的,在用戶離開網站後將被刪除。若是您須要永久存儲信息,能夠把數據存儲在數據庫中。

Session 的工做機制是:爲每一個訪客建立一個惟一的 id (UID),並基於這個 UID 來存儲變量。UID 存儲在 cookie 中,或者經過 URL 進行傳導。


開始 PHP Session

在您把用戶信息存儲到 PHP session 中以前,首先必須啓動會話。

註釋:session_start() 函數必須位於 <html> 標籤以前:

<?php session_start(); ?> <html> <body> </body> </html>

上面的代碼會向服務器註冊用戶的會話,以便您能夠開始保存用戶信息,同時會爲用戶會話分配一個 UID。


存儲 Session 變量

存儲和取回 session 變量的正確方法是使用 PHP $_SESSION 變量:

<?php session_start(); // 存儲 session 數據 $_SESSION['views']=1; ?> <html> <head> <meta charset="utf-8"> <title>菜鳥教程(runoob.com)</title> </head> <body> <?php // 檢索 session 數據 echo "瀏覽量:". $_SESSION['views']; ?> </body> </html>

輸出:

瀏覽量:1

在下面的實例中,咱們建立了一個簡單的 page-view 計數器。isset() 函數檢測是否已設置 "views" 變量。若是已設置 "views" 變量,咱們累加計數器。若是 "views" 不存在,則建立 "views" 變量,並把它設置爲 1:

<?php session_start(); if(isset($_SESSION['views'])) {     $_SESSION['views']=$_SESSION['views']+1; } else {     $_SESSION['views']=1; } echo "瀏覽量:". $_SESSION['views']; ?>

 


銷燬 Session

若是您但願刪除某些 session 數據,可使用 unset() 或 session_destroy() 函數。

unset() 函數用於釋放指定的 session 變量:

<?php session_start(); if(isset($_SESSION['views'])) {     unset($_SESSION['views']); } ?>

您也能夠經過調用 session_destroy() 函數完全銷燬 session:

<?php session_destroy(); ?>

註釋:session_destroy() 將重置 session,您將失去全部已存儲的 session 數據。

相關文章
相關標籤/搜索