我正在为我试图制作的测试网站制作一个简单的登录页面。每次我尝试使用硬编码密码登录时,它会给我一个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>
如果你能解决这个问题我真的很感激。谢谢
分号成功地留在第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>
删除<!DOCTYPE HTML>
,将输出发送到浏览器后无法进行头重定向。