會話控制是一種追蹤使用者的通訊方式,使用會話控制主要基於以下幾點:由於http協定的無狀態性,使得無法透過協定來建立兩次請求之間的關聯;對於通常的頁面之間的資料傳遞方式get和post而言,主要處理參數的傳遞、資料的輸入兩個頁間簡單的資料傳遞,對於一個使用者的在網站上的多個頁面,多種不同的數據,可能還有權限的不同而導致頁面的不同、操作方式的不同等等,使用get和post非常繁瑣。
##1.cookie方式
為了對使用者進行跟踪,就必須對使用者進行標記,cookie的思想就是,當使用者造訪網站的第一個頁面時,透過設定使用者的資訊標識,web伺服器將其以文字檔案的形式存放到使用者的電腦上面,這些檔案就是所謂的cookie,以鍵值對的方式存儲,當用戶再訪問第二個該網站的頁面時,將通過http頭信息,將攜帶cookie文件中的信息一起訪問服務器,並重新對剛才的用戶信息進行驗證,這樣避免了每次訪問都輸入用戶信息,可以確定多個頁面之間的訪問是不是同一用戶了。 將資訊設定為cookie的函數:setcookie($key, $value, $expire, $path, $domain, $secure)。 參數依序為:鍵、值、過期時間(UNIX時間戳,預設為0表示關閉瀏覽器則cookie消失)、存取cookie的路徑,設定後伺服器上該路徑下的腳本可造訪cookie(預設為根目錄)、存取cookie的域名,只有該網域(如www.example.com)下的網站網頁可存取cookie、是否為https安全連線才啟用cookie。 例如透過post提交表單後記錄一些資訊<?php if(isset($_POST)){ $time = time(); setcookie('user', $_POST['user'], $time+3600); // 时间参数需要比当前时间点大,以表示cookie信息的有效时间 s etcookie('data', array(1,2,3), $time+1200); // 可以存放各种数据 } 保存cookie成功后,可直接到$_COOKIE超全局数组中以键名取得该值,非常方便,如echo $_COOKIE['user'],基本的数据类型都支持 cookie的删除仍是通过setcookie进行,最好写成将时间提前的形式,或者直接写一个键名,比如在用户点击退出时进行该项操作 setcookie('user', '', time()-200); // 时间提前,相对当前时间 setcookie('user'); // 简写,只写键名
2.session方式
1.仍然是先开启会话,或者是跳转到其他页面时,再次返回已经存在的会话,需要确保前面没有输出 session_start(); // 开启或返回一个会话 2.清空$_SESSION数组中的相关变量 unset($_SESSION['robert']) // 销毁某一个变量 $_SESSION = array(); // 或者一次性全部销毁会话变量 3.清除保存在客户端的cookie,别忘了session id还在用户计算机上面 if( isset( $_COOKIE[ session_name ()])){ unset( $_COOKIE[ session_name()]); // session_name()获取sesion的名,session id也是以名和值的形式存储的 } 4.彻底销毁存储到服务器的信息 session_destroy();
四步驟走完,就結束了一次session會話。
3.使用會話控制的基本步驟如下:
要使用一個會話變數很簡單,使用$_SESSION陣列存取已儲存的會話變數即可,如 echo $_SESSION['mywar']; 會列印出 5。使用會話前必須先使用session_start()函數啟動一個會話。
4)註銷變數和銷毀會話
註銷變數直接使用unset即可,如unset($_SESSION['myvar']),如何要一次銷毀所有會話變數,可以使用unset ($_SESSION); 當使用完一個會話後,首先應該註銷所有的變量,然後再調用session_destroy() 來清除會話ID。
以上是如何理解PHP中的會話控制的詳細內容。更多資訊請關注PHP中文網其他相關文章!