elcomsoft wireless security au PHP中的session永不過期的解決思維及實作方法分享

WBOY
發布: 2016-07-29 08:44:50
原創
1128 人瀏覽過

我們前期開發了一個只有公司客服人員才能使用的系統──有限的幾個客服人員。就是這有限的幾個客服人員前幾天突然就提出這樣的問題:我們每隔很短一段時間(半個小時不操作頁面),正著急解決客戶問題的時候,系統卻提示需要登錄,耽誤了客戶的時間… 這很不爽!
  客戶就是上帝,唯一的上帝。於是上峰要求我們能夠實現PHP中的session永不過期,除非我們的客服人員人為的讓他過期了。出於安全性的考慮我很不理解這種永不過期的行為;出於懶惰的原因我真的不想修改以前的程序。但是沒有辦法,我依然需要改。
  不修改程序是最好的方法了,因為如果修改程序,測試部一定非常鬱悶像我一樣,那麼只能修改系統環境配置,其實很簡單,打開php.ini設定文件,修改三行如下:
  1、session.use_cookies
  把這個的值設為1,利用cookie來傳遞sessionid
  2、session.cookie_lifetime
   2、session.cookie_lifetime
   ,代表瀏覽器一關閉SessionID就作廢…就是因為這個所以PHP的session不能永久使用! 那我們把它設定為一個我們認為很大的數字吧,999999999怎麼樣,可以的!就這樣。
  3、session.gc_maxlifetime
  這個是Session資料在伺服器端儲存的時間,如果超過這個時間,那麼Session資料就會自動刪除! 那我們也把它設定為99999999。
  就這樣一切ok了,當然你不相信的話就測試一下看看——設定一個session值過個10天半個月的回來看看,如果你的電腦沒有斷電或者宕機,你仍然可以看見這個sessionid。
  當然也可能你沒有控制伺服器的權限並不能像我一樣幸運的可以修改php.ini設置,一切依靠我們自己也是有辦法的,當然就必須利用到客戶端存儲cookie了,吧得到的sessionID儲存到客戶端的cookie裡面,設定這個cookie的值,然後把這個值傳遞給session_id()這個函數,具體做法如下:

複製程式碼

程式碼如下:



session_start(); // 啟動Session
$_SESSION['count']; // 註冊Session變數Count
isset($PHPSESSID) ?session_id($PHPSESSID):$PHPSESSID = session_id();
// 如果設定了$PHPSESSID,就將SessionID賦值為$PHPSESSID,否則產生SessionID
$_SESSION['count']++ / / 變數count加1
setcookie('PHPSESSID', $PHPSESSID, time()+3156000); // 儲存SessionID到Cookie中
echo $count; // 顯示Session變數count的值
? >



如果很久以後(多久?你自己看吧)你回來刷新這個頁面,輸出的數字比你走的時候大了1那就對了!如果大了很多,估計是誰動你電腦了,這次測試就不準確了,呵呵…重新出去一會兒吧!

  注意:在setcookie一行中的'PHPSESSID'並不是一定的,如果你遇到有個患有修改狂疾病的網管員,他可能對其做了修改,最好的方法是用phpinfo()這個函數看看,確認一下session.name一項的值,比較科學。

以上就介紹了elcomsoft wireless security au PHP中的session永不過期的解決思路及實現方法分享,包括了elcomsoft wireless security au方面的內容,希望對PHP教程有興趣的朋友有所幫助。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!