首頁 > 後端開發 > php教程 > php操作Session和Cookie

php操作Session和Cookie

伊谢尔伦
發布: 2016-11-26 16:24:54
原創
942 人瀏覽過

我們追蹤使用者資訊時需要用到Session和Cookie,例如使用者登入驗證、記錄使用者瀏覽歷史,儲存購物車數據,限制使用者會話有效時間等。今天我們來了解下PHP是如何操作Session和Cookie的。

Session

PHP的$_SESSION可以存儲當前用戶資料訊息,用戶訪問WEB網站的時候,PHP會給每個訪問的用戶創建一個session ID,該ID是唯一ID,保存在客戶機上,而用戶的會話資料是儲存到服務端的,PHP可以對每個不同的使用者資訊進行存儲,當會話過期後,使用者session資訊也會失效。

使用Session,在使用PHP session時,一定要在頁頭加上session_start(),告訴伺服器開始使用session了,而且在它之前應該沒有任何輸出,否則會報錯。

  <?php 
session_start();  
  //PHP 代码...  ?>
登入後複製

PHP設定與取得Session

我們可以使用PHP的$_SESSION來設定和取得Session數據,如:

<?php 
session_start();   
  //设置一个session值  $_SESSION["name"] = "Hello";  
  //将session以数组形式保存  $_SESSION["arr"] = array(&#39;name&#39; => &#39;Hello&#39;, &#39;url&#39; => &#39;http://www.helloweba.com&#39;, &#39;type&#39;=> &#39;website&#39;);  ?>
登入後複製

一旦儲存了Session數據,我們就可以在網站上使用Session,例如我們在另一個頁面就可以取得Session資料:

 <?php 
session_start();   
  //获取保存的Session name   echo $_SESSION["name"]; 
  //打印数组session 
print_r($_SESSION["arr"]);  ?>
登入後複製

PHP刪除Session

當不再使用Session時,我們可以使用PHP將session資料刪除並清空,方法如下:

<?php  unset($_SESSION["name"]);  ?>
登入後複製

如果要清空目前使用者所有的​​Session可以使用下列代碼:

 <?php 
session_destroy();  ?>
登入後複製

Cookie

Cookie是由用戶訪問的網站服務端給當前客戶機上創建的一個臨時文件,用來保存用戶信息,以便用戶下次繼續訪問該網站時,網站服務器能識別用戶信息,常見的Cookie用來保存使用者介面,使用者ID等資料。

PHP設定Cookie

我們可以使用PHP的setcookie()在客戶端建立cookie,這個函數提供主要的三個參數,cookie名稱,值和有效時長。

<?php  $cookie_val = &#39;Chrome&#39;;  
setcookie("browser", $cookie_val, time()+3600);   ?>
登入後複製

執行以上程式碼,將會建立一個名稱為Chrome的Cookie,並且在客戶端儲存1小時,1小時後該cookie資訊失效。

PHP接收Cookie

當Cookie創建後,我們很容易就可以獲取到cookie值,使用PHP的$_COOKIE,用法如下:

<?php  if(isset($_COOKIE[&#39;browser&#39;])) { 
    echo &#39;您的浏览器是:&#39; . $_COOKIE[&#39;browser&#39;]; 
}  ?>
登入後複製

PHP刪除Cookie

如果你想徹底在你的機器上刪除保存你的機器上刪除保存你的機器上刪除的cookie訊息,可以使用以下代碼:

  <?php 
setcookie("browser", "", time()-3600);  ?>
登入後複製

以上代碼將名稱為browser的cookie清空,並將有效期設定到1小時前,完全清空了cookie訊息。


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板