程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP通過session id 實現session共享和登錄驗證的代碼

PHP通過session id 實現session共享和登錄驗證的代碼

編輯:關於PHP編程

先說說,這個機制的用途吧,到現在為止戰地知道這個機制有兩個方面的用途:

首先,多服務器共享session問題,這個大家應該都能夠理解的,當一個網站的用戶量過大,就會使用服務器集群,例如專門有一個登錄用的服務器。用戶通過登錄服務器登錄之後,登錄服務器保存了用戶的登錄信息session,而其他受訪問的服務器,例如電影服務器沒有這個session,那麼我們就要通過一個session的唯一標識來共享這個session了——具體session的共享超出了本文的范圍,請自行查閱資料。

第二個用途就是,驗證同一用戶的不同會話,這個比較難理解。這樣說吧,一個用戶並非通過浏覽器來請求連接,而是通過socket或者其它方式來請求數據的時候,我們首先要對他進行用戶登錄驗證,驗證成功之後,就下發一個sessionid給他,然後他每次請求的時候就攜帶這個sessionid,我們通過這個sessionid來判斷session是否已經存在,如果存在我們就認定用戶已經登錄……

對於第一個問題,我們可以把sessionid保存在數據庫中得以實現,這個方法比較安全而且應用廣泛,但是不是我們討論的范圍哦

第二個問題,其實已經很簡單了,看一下代碼

首先驗證的時候產生一個sessionid;
復制代碼 代碼如下:
<?php
Session_start();
$sessionId = session_id();//得到sessionid
//將session下發給客戶端
.........
?>

客戶端攜帶sessionid這個變量來請求數據
復制代碼 代碼如下:
<?php
Session_id(‘$sessionid');//注意這個時候session_id()這個函數是帶有參數的
Session_start();//這個函數必須在session_id()之後
?>

這個時候session已經是登錄驗證時候的session了。
注意:在sessionServer.php中如果使用thinkphp等其他自動啟動session_start();函數的框架時,必須先調用session_destory()函數來清空session。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved