Stvarno ne mogu da pronadjem sta se salje u header pre nego sto bi trebalo... najvise me buni to sto u lokalu sve radi dobro.
login.php radi prosto.. proveri da li postoje cookie, ako postoje i ako su odgovarajuci salje na members.php stranicu. Ako cookie ne postoje prikazuje se login forma. Kada se pritisne submit podaci se preko posta proveravaju u bazi i ako odgovaraju naprave se cookie i preko header saljem na members stranu. Evo koda:
Code:
<?php
// Konekcija na bazu
include ("konekcija.inc.php");
// Provera da li postoje cookie
if(isset($_COOKIE['ID_my_site']))
// ako postoje redirekt na members stranu
{
$username = $_COOKIE['ID_my_site'];
$pass = $_COOKIE['Key_my_site'];
$check = mysql_query("SELECT * FROM users WHERE username = '$username'")or die(mysql_error());
while($info = mysql_fetch_array( $check ))
{
if ($pass != $info['password'])
{
}
else
{
header("Location: login/members.php");
}
}
}
// Ako je login forma submitovana
if (isset($_POST['submit'])) {
// Da li su popunjena oba polja
if(!$_POST['username'] | !$_POST['pass']) {
die('Nisu popunjena odgovarajuca polja.');
}
// provera da li username postoji
if (!get_magic_quotes_gpc()) {
$_POST['username'] = addslashes($_POST['username']);
}
$check = mysql_query("SELECT * FROM users WHERE username = '".$_POST['username']."'")or die(mysql_error());
// greska ako ne postoji username
$check2 = mysql_num_rows($check);
if ($check2 == 0) {
die('Korisnicko ime ne postoji u bazi. <a href=add.php>Kliknite ovde za registraciju</a>');
}
while($info = mysql_fetch_array( $check ))
{
// md5 password
$_POST['pass'] = stripslashes($_POST['pass']);
$info['password'] = stripslashes($info['password']);
$_POST['pass'] = md5($_POST['pass']);
// greska ako password nije dobar
if ($_POST['pass'] != $info['password']) {
die('Neispravna lozinka. Molim pokusajte ponovo.');
}
else
{
// ako je login ok napravi cookie
$_POST['username'] = stripslashes($_POST['username']);
$hour = time() + 3600;
setcookie(ID_my_site, $_POST['username'], $hour );
setcookie(Key_my_site, $_POST['pass'], $hour, );
// redirekt na members stranu
header("Location: login/members.php");
}
}
} else {
// ako nema cookie
?>
<form action="<?php echo $_SERVER['PHP_SELF']?>" method="post">
<table border="0">
<tr><td>Korisnicko ime:</td><td>
<input type="text" name="username" maxlength="10">
</td></tr>
<tr><td>Lozinka:</td><td>
<input type="password" name="pass" maxlength="10">
</td></tr>
<tr><td colspan="2" align="right">
<input type="submit" name="submit" value=" Uloguj se ">
</td></tr>
<tr><td colspan="2"> </td></tr>
<tr><td colspan="2" align="right"><a href="#"><font size="2">Zaboravljena lozinka?</font></a> </td></tr>
</table>
</form>
<?php
}
?>
Zatim na members strani proveram cookie i ako je sve ok prikazuje se stranica za registrovane. evo kod za members.php
Code:
// Provera da li postoje cookie
if(isset($_COOKIE['ID_my_site']))
{
$username = $_COOKIE['ID_my_site'];
$pass = $_COOKIE['Key_my_site'];
$check = mysql_query("SELECT * FROM users WHERE username = '$username'")or die(mysql_error());
while($info = mysql_fetch_array( $check ))
{
// ako cookie ima pogresan password, poslati na index stranu
if ($pass != $info['password'])
{ header("Location: index.php");
}
// ako je sve ok prikaz member strane...
else
{
// ovde sada ide ostatak stranice...
Kada ovo postavim na mrezu dobijam gresku:
Warning: Cannot modify header information - headers already sent by (output started at url do fajla... .awardspace.com/login/konekcija.inc.php:2) in url... /login.php on line 76
Isto to dobijam za linije 76 , 77 i 80 a to je:
Code:
76: setcookie(ID_my_site, $_POST['username'], $hour);
77: setcookie(Key_my_site, $_POST['pass'], $hour);
78:
79: // redirekt na members stranu
80: header("Location: login/members.php");
Pokusao sam da ubacim parametre za subdomen prilikom setovanja cookie, ali isto dobijam
setcookie(ID_my_site, $_POST['username'], $hour, '/', ".awardspace.com" );
Probao sam u action formi da upisem umeseto php_self ime strane i url strane.., medjutim nema razlike.
Eto, ako neko vidi neku gresku u kodu... mada pokazalo bi se to i na localhostu.