我們跟蹤使用者資訊時需要用到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('name' => 'Hello', 'url' => 'http://www.helloweba.com', 'type'=> 'website'); ?>
一旦儲存了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 = 'Chrome'; setcookie("browser", $cookie_val, time()+3600); ?>
運行以上代碼,將會建立一個名稱為Chrome的Cookie,並且在用戶端儲存1個小時,1小時後該cookie資訊失效。
PHP接收Cookie
當Cookie建立後,我們很容易就可以擷取到cookie值,使用PHP的$_COOKIE,用法如下:
<?php if(isset($_COOKIE['browser'])) { echo '您的瀏覽器是:' . $_COOKIE['browser']; } ?>
PHP刪除Cookie
如果你想徹底在你的機器上刪除儲存的cookie資訊,可以使用以下代碼:
<?php setcookie("browser", "", time()-3600); ?>
以上代碼將名稱為browser的cookie清空,並將有效期間設定到1小時前,完全清空了cookie資訊。