我制作了一个锁定文件,看看是否有人登录某些页面,我很好奇它是否真的足够安全,或者人们可以轻易绕过这个锁。
这是我目前的代码:
<?php
session_start();
if ((isset($_POST['user'])) && (isset($_POST['pass']))) {
$_SESSION['user'] = $_POST['user'];
$_SESSION['pass'] = $_POST['pass'];
}
include("config.php");
if ((isset($_SESSION['user']) && (isset($_SESSION['pass'])))) {
$sql = "SELECT count(*) FROM `users` WHERE user = :name and pass = :pass";
$result = $db->prepare($sql);
$result->bindValue(':name', $_SESSION['user']);
$result->bindValue(':pass', $_SESSION['pass']);
$result->execute();
$number_of_rows = $result->fetchColumn();
if ($number_of_rows !== 1){
echo "ERROR - USER AND PASS DO NOT MATCH";
} else { echo "SUCCESS!"; }
} else { echo "YOU NEVER LOGGED IN!"; }
?>
我觉得因为它检查数据库是否有用户和密码匹配,但实际上并没有任何解决方法,但与此同时我对PHP有点新,并且真的不知道。
答案 0 :(得分:1)
您可以在代码之上添加此内容。
<?php
session_start();
if(empty($_SESSION['user']) && empty($_SESSION['pass']))
{
header("location:your_login_page.php");
exit();
}
如果用户试图进入会话或注册会员区域,此代码会自动将用户重定向到登录页面....