Hello,
I have seen this question asked before but for some reason I still can't see where the error is in my code. I am a newbie to PHP so that could very well be the problem right there. 😛 Anyway, I am getting this error:
Warning: Cannot modify header information - headers already sent by (output started at /home/careac5/public_html/login.php:18) in /home/careac5/public_html/login.php on line 78
My code is as follows, and this is exactly how it is in the file.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>CAREA - Login PHP</title>
<link rel="stylesheet" type="text/css" href="carea.css"/>
</head>
<body id="container">
<div id="header"></div>
<div id="navigation"><br>
<a class="nav" href="index.htm">Home</a><br><br>
<a class="nav" href="profile.htm">Company Profile</a><br><br>
<a class="nav" href="services.htm">Services & Information</a><br><br>
<a class="nav" href="password.htm">Members Only</a><br><br>
<a class="nav" href="careers.htm">Careers</a><br><br>
<a class="nav" href="contact.htm">Contact Us</a><br><br>
<a class="nav" href="links.htm">Links</a><br><br>
<a class="nav" href="privacy.htm">Privacy of Information</a><br><br>
</div>
<div id="content">
<?php
// Connects to your Database
$dbh = mysql_connect ("localhost", "*****", "******") or die ('I cannot connect to the database because: ' . mysql_error());
mysql_select_db ("********", $dbh);
//Checks if there is a login cookie
if(isset($_COOKIE['ID_my_site']))
//if there is, it logs you in and directes you to the members page
{
$username = $_COOKIE['ID_my_site'];
$pass = $_COOKIE['Key_my_site'];
$check = mysql_query("SELECT * FROM users WHERE user = '$username'")or die(mysql_error());
while($info = mysql_fetch_array( $check ))
{
if ($pass != $info['password'])
{
}
else
{
header("Location: members.htm");
}
}
}
//if the login form is submitted
if (isset($_POST['submit']))
{
// if form has been submitted makes sure they filled it in
if(!$_POST['username'] | !$_POST['pass']) {die('You did not fill in a required field.');
}
// checks it against the database
if (!get_magic_quotes_gpc()) {$_POST['email'];
}
$check = mysql_query("SELECT * FROM users WHERE user = '".$_POST['username']."'")or die(mysql_error());
//Gives error if user dosen't exist
$check2 = mysql_num_rows($check);
if ($check2 == 0) {die('That user does not exist in our database. <a href=register.php>Click Here to Register</a>');
}
while($info = mysql_fetch_array( $check ))
{
$_POST['pass'];
$info['password'];
$_POST['pass'];
//gives error if the password is wrong
if ($_POST['pass'] != $info['password']) {die('Incorrect password, please try again.');
}
else
// if login is ok then we add a cookie
$_POST['username'];
$hour = time() + 3600;
setcookie(ID_my_site, $_POST['username'], $hour);
setcookie(Key_my_site, $_POST['pass'], $hour);
//then redirect them to the members area
header("Location: members.htm");
}
}
else {
// if they are not logged in
?>
<form action="<?php echo $_SERVER['PHP_SELF']?>" method="post">
<table border="0">
<tr><td colspan=2><h1>Login</h1></td></tr>
<tr><td>Username:</td><td>
<input type="text" name="username" maxlength="40">
</td></tr>
<tr><td>Password:</td><td>
<input type="password" name="pass" maxlength="50">
</td></tr>
<tr><td colspan="2" align="right">
<input type="submit" name="submit" value="Login">
</td></tr>
</table>
</form>
<?php
}
?>
</div>
</body>
</html>
If anyone can help me that would be great. At the very least a point in the right direction would be a nice start. If you need anything more please let me know. Thanks in advance.
Chris