我正在为要创建的测试站点创建一个简单的登录页面。每次我尝试使用硬编码密码登录时,都会出现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>
如果您能帮助我解决这个问题,我将不胜感激。 谢谢
答案 0 :(得分:0)
分号位于success.php的第6行。
分号必须在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 :(得分:-1)
删除<!DOCTYPE HTML>
,将输出发送到浏览器后,您将无法重定向标题。