我尝试登录我的网站时显示HTTP错误500 [关闭]

问题描述 投票:-1回答:2

我正在为我试图制作的测试网站制作一个简单的登录页面。每次我尝试使用硬编码密码登录时,它会给我一个HTTP 500错误,这意味着我拼错了一些东西,但我似乎可以找到问题所在,因为一切似乎都很好。

这是log-in.php代码:

<!DOCTYPE HTML>

<?php
    session_start();

    $username = "user";
    $password = "pass";

    if (isset($_SESSION['loggedIn']) && $_SESSION['loggedIn'] == true){
        header("Location: success.php");       
    }

    if (isset($_POST['username']) && isset($_POST['password'])){
        if($_POST['username'] == $username && $_POST['password'] == $password){

            $_SESSION['loggedIn'] = true;
            header("Location: success.php");
        }

    }
?>

<html>
        <body>
            <form method="post" action="log-in.php">
                Username:<br/>
                <input type="text" name="username"><br/>
                Password<br/>
        <input type="password" name="password"><br/>
                <input type="submit" value="Login!">
            </form>
        </body>
</html>

这是我想要输入正确密码时显示的内容。这是success.php代码:

<!DOCTYPE HTML>

<?php
    session_start();
    if(!isset($_SESSION['loggedIn']) || $_SESSION['loggedIn'] == false){
        header("Location: index.html")
    }
?>

<html>
<h>You have logged in!</h>

</html>

如果你能解决这个问题我真的很感激。谢谢

php html http web webpage
2个回答
0
投票

分号成功地留在第6行.php。

分号必须在php中,否则会导致错误500。

 <!DOCTYPE HTML>

<?php
    session_start();
    if(!isset($_SESSION['loggedIn']) || $_SESSION['loggedIn'] == false){
        header("Location: index.html")
    }
?>

<html>
<h>You have logged in!</h>

</html>

应改为

<!DOCTYPE HTML>

<?php
    session_start();
    if(!isset($_SESSION['loggedIn']) || $_SESSION['loggedIn'] == false){
        header("Location: index.html");//semicolon added
    }
?>

<html>
<h>You have logged in!</h>

</html>

-1
投票

删除<!DOCTYPE HTML>,将输出发送到浏览器后无法进行头重定向。

© www.soinside.com 2019 - 2024. All rights reserved.