|
首先,多服務(wù)器共享session問題,這個(gè)大家應(yīng)該都能夠理解的,當(dāng)一個(gè)網(wǎng)站的用戶量過大,就會(huì)使用服務(wù)器集群,例如專門有一個(gè)登錄用的服務(wù)器。用戶通過登錄服務(wù)器登錄之后,登錄服務(wù)器保存了用戶的登錄信息session,而其他受訪問的服務(wù)器,例如電影服務(wù)器沒有這個(gè)session,那么我們就要通過一個(gè)session的唯一標(biāo)識(shí)來共享這個(gè)session了――具體session的共享超出了本文的范圍,請自行查閱資料。
第二個(gè)用途就是,驗(yàn)證同一用戶的不同會(huì)話,這個(gè)比較難理解。這樣說吧,一個(gè)用戶并非通過瀏覽器來請求連接,而是通過socket或者其它方式來請求數(shù)據(jù)的時(shí)候,我們首先要對他進(jìn)行用戶登錄驗(yàn)證,驗(yàn)證成功之后,就下發(fā)一個(gè)sessionid給他,然后他每次請求的時(shí)候就攜帶這個(gè)sessionid,我們通過這個(gè)sessionid來判斷session是否已經(jīng)存在,如果存在我們就認(rèn)定用戶已經(jīng)登錄……
對于第一個(gè)問題,我們可以把sessionid保存在數(shù)據(jù)庫中得以實(shí)現(xiàn),這個(gè)方法比較安全而且應(yīng)用廣泛,但是不是我們討論的范圍哦
第二個(gè)問題,其實(shí)已經(jīng)很簡單了,看一下代碼
首先驗(yàn)證的時(shí)候產(chǎn)生一個(gè)sessionid;
復(fù)制代碼 代碼如下:
<?php
Session_start();
$sessionId = session_id();//得到sessionid
//將session下發(fā)給客戶端
.........
?>
客戶端攜帶sessionid這個(gè)變量來請求數(shù)據(jù)
復(fù)制代碼 代碼如下:
<?php
Session_id(‘$sessionid');//注意這個(gè)時(shí)候session_id()這個(gè)函數(shù)是帶有參數(shù)的
Session_start();//這個(gè)函數(shù)必須在session_id()之后
?>
這個(gè)時(shí)候session已經(jīng)是登錄驗(yàn)證時(shí)候的session了。
注意:在sessionServer.php中如果使用thinkphp等其他自動(dòng)啟動(dòng)session_start();函數(shù)的框架時(shí),必須先調(diào)用session_destory()函數(shù)來清空session。
php技術(shù):PHP通過session id 實(shí)現(xiàn)session共享和登錄驗(yàn)證的代碼,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。