PHP利用Cookie設(shè)置用戶(hù)30分鐘未操作自動(dòng)退出功能
登陸控制器需要做的登陸成功把用戶(hù)ID等信息存入cookie:
$this->systemSetKey(array(‘name‘=>$admin_info[‘a(chǎn)dmin_name‘], ‘id‘=>$admin_info[‘a(chǎn)dmin_id‘],‘gid‘=>$admin_info[‘a(chǎn)dmin_gid‘],‘sp‘=>$admin_info[‘a(chǎn)dmin_is_super‘]));//登陸成功之后做得事情
父類(lèi)中的 systemSetKey 方法:
/** * 系統(tǒng)后臺(tái) 會(huì)員登錄后 將會(huì)員驗(yàn)證內(nèi)容寫(xiě)入對(duì)應(yīng)cookie中 * * @param string $name 用戶(hù)名 * @param int $id 用戶(hù)ID * @return bool 布爾類(lèi)型的返回結(jié)果 */ protected final function systemSetKey($user){ setNcCookie(‘sys_key‘,encrypt(serialize($user),MD5_KEY),3600,‘‘,null);//設(shè)置cookie 過(guò)期時(shí)間為30分鐘。這邊設(shè)置cookie框架有帶自己加密規(guī)則,具體是否需要加密自己看著設(shè)置。 }
父類(lèi)控制器構(gòu)造方法判斷用戶(hù)是否有登陸:
protected function __construct(){ Language::read(‘common,layout‘); /** * 驗(yàn)證用戶(hù)是否登錄 * $admin_info 管理員資料 name id */ $this->admin_info = $this->systemLogin();//取得管理員的資料,之后的子類(lèi)控制器繼承構(gòu)造方法 if ($this->admin_info[‘id‘] != 1){ // 驗(yàn)證權(quán)限 $this->checkPermission(); } //轉(zhuǎn)碼 防止GBK下用ajax調(diào)用時(shí)傳漢字?jǐn)?shù)據(jù)出現(xiàn)亂碼 if (($_GET[‘branch‘]!=‘‘ || $_GET[‘op‘]==‘a(chǎn)jax‘) && strtoupper(CHARSET) == ‘GBK‘){ $_GET = Language::getGBK($_GET); } } /** * 系統(tǒng)后臺(tái)登錄驗(yàn)證 * * @param * @return array 數(shù)組類(lèi)型的返回結(jié)果 */ protected final function systemLogin(){ //取得cookie內(nèi)容,解密,和系統(tǒng)匹配 $user = unserialize(decrypt(cookie(‘sys_key‘),MD5_KEY));//取cookie 里面儲(chǔ)存的信息,現(xiàn)在使用的框架里面自定義了cookie的加密方式 if (!key_exists(‘gid‘,(array)$user) || !isset($user[‘sp‘]) || (empty($user[‘name‘]) || empty($user[‘id‘]))){ //假如不存在說(shuō)明用戶(hù)沒(méi)登陸或者用戶(hù)長(zhǎng)時(shí)間未操作cookie時(shí)間過(guò)期 跳到登陸頁(yè)面去 @header(‘Location: index.php?mod=login&action=login‘);exit; }else { $this->systemSetKey($user);//如果用戶(hù)有登陸的話(huà),每一個(gè)操作都會(huì)重寫(xiě)刷新cookie; } return $user; }
加密函數(shù):
/** * 加密函數(shù) * * @param string $txt 需要加密的字符串 * @param string $key 密鑰 * @return string 返回加密結(jié)果 */ function encrypt($txt, $key = ‘‘){ if (empty($txt)) return $txt; if (empty($key)) $key = md5(MD5_KEY); $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_."; $ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm"; $nh1 = rand(0,64); $nh2 = rand(0,64); $nh3 = rand(0,64); $ch1 = $chars{$nh1}; $ch2 = $chars{$nh2}; $ch3 = $chars{$nh3}; $nhnum = $nh1 + $nh2 + $nh3; $knum = 0;$i = 0; while(isset($key{$i})) $knum +=ord($key{$i++}); $mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum%8,$knum%8 + 16); $txt = base64_encode(time().‘_‘.$txt); $txt = str_replace(array(‘+‘,‘/‘,‘=‘),array(‘-‘,‘_‘,‘.‘),$txt); $tmp = ‘‘; $j=0;$k = 0; $tlen = strlen($txt); $klen = strlen($mdKey); for ($i=0; $i<$tlen; $i++) { $k = $k == $klen ? 0 : $k; $j = ($nhnum+strpos($chars,$txt{$i})+ord($mdKey{$k++}))%64; $tmp .= $chars{$j}; } $tmplen = strlen($tmp); $tmp = substr_replace($tmp,$ch3,$nh2 % ++$tmplen,0); $tmp = substr_replace($tmp,$ch2,$nh1 % ++$tmplen,0); $tmp = substr_replace($tmp,$ch1,$knum % ++$tmplen,0); return $tmp; }
解密函數(shù):
/** * 解密函數(shù) * * @param string $txt 需要解密的字符串 * @param string $key 密匙 * @return string 字符串類(lèi)型的返回結(jié)果 */ function decrypt($txt, $key = ‘‘, $ttl = 0){ if (empty($txt)) return $txt; if (empty($key)) $key = md5(MD5_KEY); $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_."; $ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm"; $knum = 0;$i = 0; $tlen = @strlen($txt); while(isset($key{$i})) $knum +=ord($key{$i++}); $ch1 = @$txt{$knum % $tlen}; $nh1 = strpos($chars,$ch1); $txt = @substr_replace($txt,‘‘,$knum % $tlen--,1); $ch2 = @$txt{$nh1 % $tlen}; $nh2 = @strpos($chars,$ch2); $txt = @substr_replace($txt,‘‘,$nh1 % $tlen--,1); $ch3 = @$txt{$nh2 % $tlen}; $nh3 = @strpos($chars,$ch3); $txt = @substr_replace($txt,‘‘,$nh2 % $tlen--,1); $nhnum = $nh1 + $nh2 + $nh3; $mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum % 8,$knum % 8 + 16); $tmp = ‘‘; $j=0; $k = 0; $tlen = @strlen($txt); $klen = @strlen($mdKey); for ($i=0; $i<$tlen; $i++) { $k = $k == $klen ? 0 : $k; $j = strpos($chars,$txt{$i})-$nhnum - ord($mdKey{$k++}); while ($j<0) $j+=64; $tmp .= $chars{$j}; } $tmp = str_replace(array(‘-‘,‘_‘,‘.‘),array(‘+‘,‘/‘,‘=‘),$tmp); $tmp = trim(base64_decode($tmp)); if (preg_match("/\d{10}_/s",substr($tmp,0,11))){ if ($ttl > 0 && (time() - substr($tmp,0,11) > $ttl)){ $tmp = null; }else{ $tmp = substr($tmp,11); } } return $tmp; }
以上所述是小編給大家介紹的PHP利用Cookie設(shè)置用戶(hù)30分鐘未操作自動(dòng)退出功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
利用php+mysql來(lái)做一個(gè)功能強(qiáng)大的在線(xiàn)計(jì)算器
有天在努力的搜索計(jì)算器,發(fā)現(xiàn)都是JavaScript,而且要一個(gè)個(gè)地點(diǎn)擊,并且不能記錄,輸入計(jì)算式子時(shí)容易出錯(cuò),于是就想了想該怎樣才能讓它好用點(diǎn)呢,能夠用鍵盤(pán)直接輸入。2010-10-10Laravel框架實(shí)現(xiàn)調(diào)用百度翻譯API功能示例
這篇文章主要介紹了Laravel框架實(shí)現(xiàn)調(diào)用百度翻譯API功能,結(jié)合實(shí)例形式分析了基于Laravel框架的百度翻譯API調(diào)用相關(guān)操作技巧,需要的朋友可以參考下2019-05-05php將html轉(zhuǎn)為圖片的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇php將html轉(zhuǎn)為圖片的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05THINKPHP項(xiàng)目開(kāi)發(fā)中的日志記錄實(shí)例分析
這篇文章主要介紹了THINKPHP項(xiàng)目開(kāi)發(fā)中的日志記錄用法,以實(shí)例形式較為全面的分析了日志表的建立與相關(guān)數(shù)據(jù)庫(kù)操作方法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下2014-12-12TP3.2框架分頁(yè)相關(guān)實(shí)現(xiàn)方法分析
這篇文章主要介紹了TP3.2框架分頁(yè)相關(guān)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了TP3.2框架分頁(yè)相關(guān)步驟、功能實(shí)現(xiàn)方法與操作技巧,需要的朋友可以參考下2020-06-06使用Entrust擴(kuò)展包在laravel 中實(shí)現(xiàn)RBAC的功能
這篇文章主要介紹了使用Entrust擴(kuò)展包在laravel 中實(shí)現(xiàn)RBAC的功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03PHP PDO預(yù)處理語(yǔ)句及事務(wù)的使用
今天這篇文章,我們來(lái)簡(jiǎn)單的學(xué)習(xí)一下 PDO 中的預(yù)處理語(yǔ)句以及事務(wù)的使用,它們都是在 PDO 對(duì)象下的操作,而且并不復(fù)雜,簡(jiǎn)單的應(yīng)用都能很容易地實(shí)現(xiàn)。只不過(guò)大部分情況下,大家都在使用框架,手寫(xiě)的機(jī)會(huì)非常少。2021-06-06微信公眾號(hào)開(kāi)發(fā)之語(yǔ)音消息識(shí)別php代碼
這篇文章主要為大家詳細(xì)介紹了微信公眾號(hào)開(kāi)發(fā)之語(yǔ)音消息識(shí)別php代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08