php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法分析【當(dāng)其它地方登陸時(shí),當(dāng)前賬號(hào)失效】
本文實(shí)例講述了php 實(shí)現(xiàn)賬號(hào)不能同時(shí)登陸的方法。分享給大家供大家參考,具體如下:
解決的思路是每當(dāng)用戶登陸時(shí)我們必需記錄當(dāng)前的用戶id和session_id,如果有人在其它地方用此賬號(hào)登陸時(shí),我們把此用戶id對(duì)應(yīng)的session_id的session文件刪除,并重新記錄當(dāng)前的session_id。那么之前的用戶就失效了。
login.php代碼如下:
<?php session_start(); require 'db.php'; if(!empty($_POST['submit'])) { $uname = !empty($_POST['uname']) ? trim($_POST['uname']) : ''; $upwd = !empty($_POST['upwd']) ? trim($_POST['upwd']) : ''; //這里只是演示,實(shí)際情況是在數(shù)據(jù)庫(kù)里查詢并判斷 if($uname == 'test' && $upwd == 'test') { //這里假設(shè)test用戶id為1 $uid = 1; $session_id = session_id(); //判斷是否已有用戶登陸過(guò) $res = mysql_query("SELECT session_id FROM tb_login_state WHERE uid={$uid}"); $data = mysql_fetch_assoc($res); if(!empty($data)) { $sessionId = $data['session_id']; $sessionFilePath = session_save_path() . DIRECTORY_SEPARATOR . 'sess_' . $sessionId; //刪除上次用戶登陸的session文件 if(file_exists($sessionFilePath) && is_writable($sessionFilePath)) { @unlink($sessionFilePath); } //刪除用戶登陸信息 mysql_query("DELETE FROM tb_login_state WHERE uid={$uid}"); } //添加新的用戶登陸信息 mysql_query("INSERT INTO tb_login_state VALUES({$uid}, '{$session_id}')"); $_SESSION['userInfo'] = array( 'name' => $uname ); echo '<script type="text/javascript">alert("您已成功登陸,跳轉(zhuǎn)首頁(yè)");</script>'; echo '<script type="text/javascript">location.href="index.php" rel="external nofollow" ;</script>'; } } ?> <!DOCTYPE HTML> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>用戶登陸頁(yè)面</title> </head> <body> <form action="" method="post"> 用戶名:<input type="text" name="uname" value="" /> 密碼:<input type="password" name="upwd" value="" /> <input type="submit" name="submit" value="登陸" /> </form> </body> </html>
index.php代碼如下:
<?php header('Content-Type:text/html;charset=utf-8'); session_start(); if(!empty($_SESSION['userInfo'])) { echo '您好:', $_SESSION['userInfo']['name']; } else { header('Location:login.php'); }
db.php代碼如下:
<?php $db = mysql_connect('127.0.0.1','root','') or die('connect error'); mysql_select_db('test') or die('select db error'); mysql_query('set names utf8') or die('set names error');
tb_login_state表結(jié)構(gòu)如下:
CREATE TABLE `tb_login_state` ( `uid` int(11) unsigned NOT NULL COMMENT '用戶ID', `session_id` varchar(32) NOT NULL DEFAULT '' COMMENT '存儲(chǔ)用戶的session_id' ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶登陸狀態(tài)表';
如果是session存儲(chǔ)方式不是文件,而是存在mysql,memcache,redis中,思路其實(shí)是一樣的,都是把前一次的session_id保存。判斷用戶是否登陸過(guò),如果登陸過(guò)就讓上一次的session失效(刪除session數(shù)據(jù))。
(*通過(guò)設(shè)置session的過(guò)期時(shí)間和cookie的過(guò)期時(shí)間來(lái)讓session失效是不嚴(yán)格的,最直接的方法是直接把session文件刪除。)
推薦閱讀:
http://www.laruence.com/2012/01/10/2469.html
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《php緩存技術(shù)總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《PHP錯(cuò)誤與異常處理方法總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》、《php+mysql數(shù)據(jù)庫(kù)操作入門(mén)教程》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- PHP實(shí)現(xiàn)會(huì)員賬號(hào)單唯一登錄的方法分析
- php $_SESSION會(huì)員登錄實(shí)例分享
- PHP+MYSQL會(huì)員系統(tǒng)的登陸即權(quán)限判斷實(shí)現(xiàn)代碼
- 實(shí)用PHP會(huì)員權(quán)限控制實(shí)現(xiàn)原理分析
- php+MySQL實(shí)現(xiàn)登錄時(shí)驗(yàn)證登錄名和密碼是否正確
- php session應(yīng)用實(shí)例 登錄驗(yàn)證
- php cookie 登錄驗(yàn)證示例代碼
- PHP登錄驗(yàn)證碼的實(shí)現(xiàn)與使用方法
- php自動(dòng)注冊(cè)登錄驗(yàn)證機(jī)制實(shí)現(xiàn)代碼
- php面向?qū)ο蟮挠脩舻卿浬矸蒡?yàn)證
相關(guān)文章
php基于SQLite實(shí)現(xiàn)的分頁(yè)功能示例
這篇文章主要介紹了php基于SQLite實(shí)現(xiàn)的分頁(yè)功能,結(jié)合具體實(shí)例形式分析了php操作SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)分頁(yè)功能的相關(guān)技巧與注意事項(xiàng),需要的朋友可以參考下2017-06-06PHP對(duì)象鏈?zhǔn)讲僮鲗?shí)現(xiàn)原理分析
這篇文章主要介紹了PHP對(duì)象鏈?zhǔn)讲僮?結(jié)合實(shí)例形式分析了鏈?zhǔn)讲僮鞯暮?jiǎn)單用法及對(duì)象鏈?zhǔn)讲僮鞯膱?zhí)行流程,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-10-10編譯php 5.2.14+fpm+memcached(具體操作詳解)
本篇文章是對(duì)編譯php5.2.14+fpm+memcached的具體操作進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06