私は3つのページを持っています:
- index.php、
- login.php と
- logout.php.
ログインしていない場合は、インデックス ページからログイン ページにリダイレクトされます。ログインしている場合は、ログアウトできるインデックス ページにリダイレクトされます。そして、すべてがうまく機能しています。しかし、それは奇妙なことです。私にはそうすべきではないようです。
私の知る限りでは。ヘッダー、setcookie、およびセッション ステートメントは、ブラウザーに出力を送信する前にのみ使用できますが、login.php ページを見ると、既に HTML コードが送信されています。なぜこれが機能しないのですか?ここで何が欠けていますか?
index.php:
<?php
if (isset ($_COOKIE['uid'])) {
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Index Page</title>
</head>
<body>
Logged in with UID: <?php echo $_COOKIE['uid']; ?>
<br/>
<a href="logout.php">Log Out</a>
</body>
</html>
<?php
} else {
/* If no UID is in the cookie, we redirect to the login page */
header('Location: http://localhost/cookie/login.php');
}
?>
login.php:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Login</title>
</head>
<body>
<?php
function check_auth() {
return 4;
}
if (isset ($_POST['login']) && ($uid = check_auth($_POST['email'], $_POST['password'])))
{
/* User succesfully logged in, setting cookie */
setcookie('uid', $uid, time() + 14400, '/');
header('Location: http://localhost/cookie/index.php');
} elseif (isset($_COOKIE['uid'])) {
/* If try to go to login.php when you already logged in, we redirect to the index page */
header ('Location: http://localhost/cookie/index.php');
} else {
?>
<h1>Log-in</h1>
<form method="post" action="login.php">
<table>
<tr><td>E-mail address:</td><td><input type='text' name='email'/></td></tr>
<tr><td>Password:</td><td><input type='password' name='password'/></td></tr>
<tr><td colspan='2'><input type='submit' name='login' value='Log in'/></td></tr>
</table>
</form>
<?php
}
?>
</body>
</html>
logout.php:
<?php
setcookie('uid', '', time() - 86400, '/');
header('Location: http://localhost/cookie/login.php');
?>