我們追蹤使用者資訊時需要用到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訊息。