时间:2021-05-26
本文实例讲述了php 实现账号不能同时登陆的方法。分享给大家供大家参考,具体如下:
解决的思路是每当用户登陆时我们必需记录当前的用户id和session_id,如果有人在其它地方用此账号登陆时,我们把此用户id对应的session_id的session文件删除,并重新记录当前的session_id。那么之前的用户就失效了。
login.php代码如下:
<?phpsession_start(); require 'db.php'; if(!empty($_POST['submit'])) { $uname = !empty($_POST['uname']) ? trim($_POST['uname']) : ''; $upwd = !empty($_POST['upwd']) ? trim($_POST['upwd']) : ''; //这里只是演示,实际情况是在数据库里查询并判断 if($uname == 'test' && $upwd == 'test') { //这里假设test用户id为1 $uid = 1; $session_id = session_id(); //判断是否已有用户登陆过 $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("您已成功登陆,跳转首页");</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>用户登陆页面</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代码如下:
<?phpheader('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表结构如下:
CREATE TABLE `tb_login_state` (`uid` int(11) unsigned NOT NULL COMMENT '用户ID',`session_id` varchar(32) NOT NULL DEFAULT '' COMMENT '存储用户的session_id') ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户登陆状态表';如果是session存储方式不是文件,而是存在mysql,memcache,redis中,思路其实是一样的,都是把前一次的session_id保存。判断用户是否登陆过,如果登陆过就让上一次的session失效(删除session数据)。
(*通过设置session的过期时间和cookie的过期时间来让session失效是不严格的,最直接的方法是直接把session文件删除。)
推荐阅读:
http:///2012/01/10/2469.html
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php缓存技术总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP错误与异常处理方法总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了php通过smtp邮件验证登陆的方法。分享给大家供大家参考,具体如下:内网的系统为了统一账号,都采用用邮件账号登陆的方式,所以有了以下程序/***
当我们使用selenium实现模拟登陆时,获取到登陆按钮元素后,直接调用它的click()方法就能实现登陆跳转,并且此时的webDriver也是指向当前页面,这
1、我们需要一个网易账号登陆,没有可以申请一个或者直接选择其他账号登陆也可以。 2、登陆了有道云笔记后登陆这个网站:http://note.youdao.
无线路由器怎么设置密码呢?只需要登陆路由器内部设置即可,方法如下:192.168.1.1进入,然后输入登陆账号与密码就可以进入了。其中登陆地址,以及登陆账号与密
php实现用户登陆简单实例前言:最近要完成的最后一个部分,就是对用户提交的数据进行管理,至于管理,那肯定就是管理员的事了,那一定涉及登陆,验证账号权限,账号是否