php有效防止同一用户多次登录 |
|
【问题描述】:同一用户在同一时间多次登录如果不能检测出来,是危险的 。因为,你无法知道是否有其他用户在登录你的账户 。如何禁止同一用户多次登录呢?
session_regenerate_id();
session_register ("username") ;
(2) 在用户数据库中开一个sessionid字段,重新产生session_id后,都更新该字段 。 $sessionid = session_id(); $db = new PDO(sqlite:softToken.db); $sql = "update userinfo set sessionid =$sessionid where username=$username and passwd=$passwd;"; $query = $db->prepare($sql); $query->execute(); (3) 建立一个session保存用户名 $_SESSION["username"] = $username; (4) 利用url重写,传递session_id
$url = "main.php?sid=".session_id();
unset($db);
echo "<font color=blue>登录成功,正在跳转!</font>" ;
header ("Location:$url");
(5) 在需要跳转的页面,起始处加入
<?php
header(Content-type:text/html; charset=utf-8);
$sessionid = $_GET[sid];
session_id($sessionid);
session_start ();
$username = $_SESSION["username"];
$db = new PDO(sqlite:softToken.db);
$sql = "select * from userinfo where username=$username and sessionid=$sessionid;";
$query = $db->prepare($sql);
$query->execute();
$user = $query->fetch(PDO::FETCH_OBJ);
if ($user->username == ""){
session_destroy();
echo "<script language=javascript type=text/javascript>" ;
echo "window.location.href = index.html;" ;
echo "</script>" ;
exit () ;
}
?>
<html>
<body>
......
</body>
</html>
以上就是php有效防止同一账号同一时间多次登录的解决方案,希望对大家解决同一账号同一时间多次登录问题有所帮助 。 |