溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

php中設(shè)置session的方法

發(fā)布時(shí)間:2020-06-01 21:18:38 來(lái)源:億速云 閱讀:309 作者:鴿子 欄目:編程語(yǔ)言

1. 客戶(hù)端沒(méi)有禁止Cookie

(1)使用session_set_cookie_params()設(shè)置 Session失效時(shí)間,此函數(shù)是 Session 結(jié)合 Cookie設(shè)置失效時(shí)間。如果要讓 Session 在一分鐘后失效,其代碼示例如下所示:

<?php
 $time = 1*60;                   //設(shè)置session失效時(shí)間
 session_set_cookie_params($time);      // 使用函數(shù)
 session_start();                 //初始化  session
 $_SESSION["username"] = 'tom';
?>

注意: session_set_cookie_params() 必須要在 session_start()之前調(diào)用。

說(shuō)明:不推薦使用此函數(shù),此函數(shù)在一些瀏覽器上會(huì)出現(xiàn)問(wèn)題。 所以一般會(huì)用手動(dòng)設(shè)置失效時(shí)間。

(2)使用 setcookie()函數(shù)可對(duì) Session 設(shè)置失效時(shí)間,要讓 Session 在一分鐘后失效,其代碼示例如下所示:

<?php
 session_start();
 // session失效時(shí)間
 $time = 1*60;                   
 // 使用 setcookie 手動(dòng)設(shè)置 session失效時(shí)間     
 setcookie(session_name(),session_id(),time()+$time.'/');   
 $_SESSION["username"] = 'tom';
?>

說(shuō)明: 在上例代碼 setcookie()函數(shù)中,session_name 是 Session的名稱(chēng), session_id 是判斷客戶(hù)端用戶(hù)的標(biāo)識(shí),因?yàn)?session_id 是隨機(jī)產(chǎn)生的唯一名稱(chēng), 所以Session 是相對(duì)安全的。失效時(shí)間和 Cookie 的失效時(shí)間一樣,最后一個(gè)參數(shù)為可選參數(shù),是放置 Cookie 的路徑。

2. 客戶(hù)端禁止Cookie

當(dāng)客戶(hù)端禁用 Cookie 時(shí), Session頁(yè)面間傳遞會(huì)失效,可以將客戶(hù)端禁止 Cookie 想象成一家大型連鎖超市,如果在其中一家超市內(nèi)辦理了會(huì)員卡, 但是超市之間沒(méi)有聯(lián)網(wǎng),那么會(huì)員卡就只能在辦理的那家超市使用。 怎么解決這個(gè)問(wèn)題有以下的幾種方法可供選擇:

(1)在登陸之前提醒用戶(hù)必須打開(kāi) Cookie,這是很多論壇的做法。

(2)設(shè)置php.ini 文件中的 session.use_trans_sid =1,或者編譯時(shí)打開(kāi) -enable-trans-sid 選項(xiàng),讓PHP自動(dòng)跨頁(yè)面?zhèn)鬟f session_id。

(3)通過(guò) GET方法,隱藏表單傳遞 session_id。

(4)使用文件或者數(shù)據(jù)庫(kù)存儲(chǔ) session_id,在頁(yè)面間傳遞中手動(dòng)調(diào)用。

以上第2種方法不做詳細(xì)的介紹,因?yàn)橛脩?hù)不能修改服務(wù)器中的php.ini文件。第3中方法我們就不可以使用 Cookie 設(shè)置失效時(shí)間,但是登錄情況沒(méi)有變化。 第4種也是最為重要的一種,在開(kāi)發(fā)企業(yè)級(jí)網(wǎng)站時(shí),如果遇到

session文件 使服務(wù)器速度變慢,就可以使用。這里我們介紹一下第3種方法使用 GET 方法傳輸,其示例代碼如下所示,接收頁(yè)面頭部的代碼:

<?php
  $session_name = session_name();        //取得 session 名稱(chēng)
  $session_id = $_GET[$session_name];    // 取得 session_id GET方式
  session_id($session_id);               // 關(guān)鍵步驟
  session_start();
  $_SESSION['admin'] = 'soft';
?>

說(shuō)明: Session 為請(qǐng)求該頁(yè)面之后會(huì)產(chǎn)生一個(gè) session_id ,如果這時(shí)禁止了 Cookie 就無(wú)法傳遞 session_id,在請(qǐng)求下一個(gè)頁(yè)面是將會(huì)重新產(chǎn)生一個(gè) session_id ,這樣就造成了 session 在頁(yè)面間傳遞失效。

以上就是php中session時(shí)間設(shè)置淺析的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注億速云其它相關(guān)文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI