这可以作为安全锁定文件传递吗?



我制作了一个锁定文件以查看人们是否在某些页面上登录,我很好奇它是否真的足够安全,可以上线,或者人们是否可以轻松绕过此锁定。

这是我目前的代码:

<?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 有点陌生,真的不知道。

你可以把它添加到你的代码之上。

<?php
session_start();
if(empty($_SESSION['user']) && empty($_SESSION['pass']))
{
header("location:your_login_page.php");
exit();
}

此代码会自动将用户重定向到登录页面,如果他们试图进入会话或注册会员区。

最新更新