• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

question-closed Ciągle wyświetlający sie napis "Nieprawidłowy login lub hasło" na własnej stronie

Object Storage Arubacloud
0 głosów
2,086 wizyt
pytanie zadane 26 sierpnia 2015 w PHP przez francus11 Gaduła (3,250 p.)
zamknięte 26 sierpnia 2015 przez francus11
Ostatnio uczę się tworzyc strony WWW według poradników z kanału YT Mirosław Zelent. Gdy doszedłem do momentu, gdzie  napisałem skryp PHP odpowiedzialny za wyświetlanie na stronie komunikatu "Nieprawidłowy login lub hasło", on wyświetlał się też przy pierwszym wyświetleniu strony. Myślałem, że problem występuje w moim kodzie, ale wszystko było dobrze. Następnie zaloadowałem do XAMPPa pliki z poradnika, ale problem też występował.

Pytanie rodzi się jedno - co tworzy ten błąd, skoro on występuje nawet w plikach od autora poradnika???
komentarz zamknięcia: Zakończony

8 odpowiedzi

+2 głosów
odpowiedź 26 sierpnia 2015 przez Schizohatter Nałogowiec (39,600 p.)
1. Pokaż kod
komentarz 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)
<?php
	session_start();
?>
<!DOCTYPE HTML>
<html lang="pl">
<head>
	<meta charset="utf-8"/>
	<meta htt-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
	<title>Osadnicy - Gra przeglądarkowa</title>
</head>

<body>

	Tylko martwi ujrzeli koniec wojny - Platon<br/><br/>

	<form action="zaloguj.php" method="post">
		
		Login: <br/> <input type="text" name="login"/><br/>
		Hasło: <br/> <input type="password" name="haslo"/><br/>
		<input type="submit" value="Zaloguj się"/>
		
		</form>
<?php
	if (isset($_SESSION['blad'])) echo $_SESSION['blad'];
?>
</body>
</html>

 

0 głosów
odpowiedź 26 sierpnia 2015 przez Lukasz Bywalec (2,320 p.)
podaj kod PHP odpowiedzialny za sprawdzanie w bazie danych i wyswietlanie błędu a nie formularz..
0 głosów
odpowiedź 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)
<?php
    session_start();
?>
<!DOCTYPE HTML>
<html lang="pl">
<head>
    <meta charset="utf-8"/>
    <meta htt-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
    <title>Osadnicy - Gra przeglądarkowa</title>
</head>
 
<body>
 
    Tylko martwi ujrzeli koniec wojny - Platon<br/><br/>
 
    <form action="zaloguj.php" method="post">
         
        Login: <br/> <input type="text" name="login"/><br/>
        Hasło: <br/> <input type="password" name="haslo"/><br/>
        <input type="submit" value="Zaloguj się"/>
         
        </form>
<?php
    if (isset($_SESSION['blad'])) echo $_SESSION['blad'];
?>
</body>
</html>

 

0 głosów
odpowiedź 26 sierpnia 2015 przez DL TD Nałogowiec (36,710 p.)

Chyba wiem co powoduje ten "błąd" Pan Mirosław nie umieścił w pliku index.php kodu który usuwa zmienną sesyjną blad. W pliku index.php na samym dole gdzie jest if dodaj pod instrukcją echo unset($_SESSION['blad']);

Proste i skuteczne rozwiązanie. Po następnym refresh problem będzie znikał, gdyż zmienna nie będzie istnieć :)

EDIT: Widzę, że dodałeś kod. To super. Podmień ten if na taki:

if (isset($_SESSION['blad'])) {
     echo $_SESSION['blad'];
     unset($_SESSION['blad']);
}

 

0 głosów
odpowiedź 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)

index.php

<?php
	session_start();
?>
<!DOCTYPE HTML>
<html lang="pl">
<head>
	<meta charset="utf-8"/>
	<meta htt-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>
	<title>Osadnicy - Gra przeglądarkowa</title>
</head>

<body>

	Tylko martwi ujrzeli koniec wojny - Platon<br/><br/>

	<form action="zaloguj.php" method="post">
		
		Login: <br/> <input type="text" name="login"/><br/>
		Hasło: <br/> <input type="password" name="haslo"/><br/>
		<input type="submit" value="Zaloguj się"/>
		
		</form>
<?php
	if (isset($_SESSION['blad'])) echo $_SESSION['blad'];
?>
</body>
</html>

zaloguj.php

<?php

    session_start();
    
    if ((!isset($_POST['login'])) || (!isset($_POST['haslo'])))
    {
        header('Location: index.php');
        exit();
    }

    require_once "connect.php";

    $polaczenie = @new mysqli($host, $db_user, $db_password, $db_name);
    
    if ($polaczenie->connect_errno!=0)
    {
        echo "Error: ".$polaczenie->connect_errno;
    }
    else
    {
        $login = $_POST['login'];
        $haslo = $_POST['haslo'];
        
        $login = htmlentities($login, ENT_QUOTES, "UTF-8");
        $haslo = htmlentities($haslo, ENT_QUOTES, "UTF-8");
    
        if ($rezultat = @$polaczenie->query(
        sprintf("SELECT * FROM uzytkownicy WHERE user='%s' AND pass='%s'",
        mysqli_real_escape_string($polaczenie,$login),
        mysqli_real_escape_string($polaczenie,$haslo))))
        {
            $ilu_userow = $rezultat->num_rows;
            if($ilu_userow>0)
            {
                $_SESSION['zalogowany'] = true;
                
                $wiersz = $rezultat->fetch_assoc();
                $_SESSION['id'] = $wiersz['id'];
                $_SESSION['user'] = $wiersz['user'];
                $_SESSION['drewno'] = $wiersz['drewno'];
                $_SESSION['kamien'] = $wiersz['kamien'];
                $_SESSION['zboze'] = $wiersz['zboze'];
                $_SESSION['email'] = $wiersz['email'];
                $_SESSION['dnipremium'] = $wiersz['dnipremium'];
                
                unset($_SESSION['blad']);
                $rezultat->free_result();
                header('Location: gra.php');
                
            } else {
                
                $_SESSION['blad'] = '<span style="color:red">Nieprawidłowy login lub hasło!</span>';
                header('Location: index.php');
                
            }
            
        }
        
        $polaczenie->close();
    }
    
?>

connect.php

<?php

	$host = "localhost";
	$db_user = "root";
	$db_password = "";
	$db_name = "osadnicy";

?>

gra.php

<?php

    session_start();
    
    if (!isset($_SESSION['zalogowany']))
    {
        header('Location: index.php');
        exit();
    }
    
?>
<!DOCTYPE HTML>
<html lang="pl">
<head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
    <title>Osadnicy - gra przeglądarkowa</title>
</head>

<body>
    
<?php

    echo "<p>Witaj ".$_SESSION['user'].'! [ <a href="logout.php">Wyloguj się!</a> ]</p>';
    echo "<p><b>Drewno</b>: ".$_SESSION['drewno'];
    echo " | <b>Kamień</b>: ".$_SESSION['kamien'];
    echo " | <b>Zboże</b>: ".$_SESSION['zboze']."</p>";
    
    echo "<p><b>E-mail</b>: ".$_SESSION['email'];
    echo "<br /><b>Dni premium</b>: ".$_SESSION['dnipremium']."</p>";
    
?>

</body>
</html>

 

komentarz 26 sierpnia 2015 przez DL TD Nałogowiec (36,710 p.)
Dzięki za kod. Zobacz moją odpowiedź :)
0 głosów
odpowiedź 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)
przywrócone 26 sierpnia 2015 przez francus11
niestety to nic nie daje
komentarz 26 sierpnia 2015 przez DL TD Nałogowiec (36,710 p.)
Odpisuj konkretnej osobie bo nw komu odpisujesz i co niedziała :)
0 głosów
odpowiedź 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)

A gdyby przekształcić

if (isset($_SESSION['blad'])) 
echo $_SESSION['blad'];

tak, żeby wyświetlał się dopiero wtedy, gdy plik zaloguj.php odesłał nas z powrotem do index.php, bo jak na razie index.php traktuje ten skrypt jako napis, który wyświetla się jako podstawowa część strony, a nie warunkowa. Masz pomysł jak to przekształcić, bo ja na razie jestem zielony w tym temacie.

komentarz 26 sierpnia 2015 przez DL TD Nałogowiec (36,710 p.)
że co? Zmienna sesyjna wyświetla się jeśli istnieje. A tworzona jest w zaloguj.php.
0 głosów
odpowiedź 26 sierpnia 2015 przez francus11 Gaduła (3,250 p.)
Problem zakończony. Wyciąłem, zapisałem i wkleiłem kod w każdym pliku. Trochę to niemożliwe, ale grunt że problem rozwiązany :)
komentarz 26 sierpnia 2015 przez DL TD Nałogowiec (36,710 p.)
w takim razie zamknij temat...

Podobne pytania

–1 głos
1 odpowiedź 368 wizyt
0 głosów
1 odpowiedź 806 wizyt
pytanie zadane 28 lutego 2017 w PHP przez Mateusz Arabczyk Początkujący (450 p.)
0 głosów
2 odpowiedzi 495 wizyt

92,575 zapytań

141,424 odpowiedzi

319,649 komentarzy

61,960 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...