0

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

这是我目前的代码:

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

4

1 回答 1

1

您可以将其添加到您的代码之上。

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

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

于 2013-10-21T19:35:19.727 回答