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

Blad składni ?

Object Storage Arubacloud
0 głosów
392 wizyt
pytanie zadane 31 lipca 2018 w PHP przez Michal93 Nowicjusz (190 p.)

Prosze o pomoc przy błędzie składni, nie widze gdzie on sie znajduje. Z góry dziekuje

Parse error: syntax error, unexpected '$rezultat' (T_VARIABLE) in C:\xampp\htdocs\nauka2\sprawdzenie.php on line 19

if(isset($_POST['add'])){
require_once "baza.php";


 $login = $_POST['nick'];
 $login = htmlentities($login, ENT_QUOTES, "UTF-8");
 

        $rezultat = $polaczenienie->query(sprintf("SELECT * FROM blog WHERE imie='$login'", mysqli_real_escape_string($polaczenienie,$login)))
        $rezultat->bindValue(':imie', $login, PDO::PARAM_STR)
        $rezultat->execute();
    
    
       
       $iluUrzytkownikow = $rezultat->rowCount();
       
       if($iluUrzytkownikow > 0)
       {
           $wiersz = $rezultat->fetch_assoc();
           
           if(password_verify($haslo, $wiersz['haslo']))
           {
               $_SESSION['zalogowany'] = true;
               $_SESSION['nick'] = $wiersz['imie'];
               
               unset($_SESSION['blad']);
			   $rezultat->free_result();
			   header('Location: admin.php');  
           
           
          }
           else 
				{
					$_SESSION['blad'] = '<span style="color:red">Nieprawidłowy login lub hasło!</span>';
					header('Location: index.php');
				}
           
      }
       else {
				
				$_SESSION['blad'] = '<span style="color:red">Nieprawidłowy login lub hasło!</span>';
				header('Location: index.php');
				
			}
       $rezultat->free_result();
   
}else
{
    unset($_SESSION['blad']);
}

a linijka 19 to:

 $rezultat->bindValue(':imie', $login, PDO::PARAM_STR)

 

1 odpowiedź

0 głosów
odpowiedź 31 lipca 2018 przez OdsetekGlupoty Pasjonat (15,360 p.)
edycja 31 lipca 2018 przez OdsetekGlupoty
Witam,

Jeżeli pojawia się błąd z serii "Unexpected", to znaczy że najprawdopodobniej brakuje jakiegoś średnika, dokończenia danej funkcji lub nie domknięcia klamry. W Twoim wypadku w poprzedniej linijce (18) brakuje średnika na końcu.

EDIT: W kolejnej linii też brakuje średnika. Postaraj się zwracać na średniki większą uwagę, bo to jeden znaczek a jak widać wywala błędy.
komentarz 2 sierpnia 2018 przez Michal93 Nowicjusz (190 p.)
Właśnie nie. I to mnie dziwi ...
komentarz 2 sierpnia 2018 przez OdsetekGlupoty Pasjonat (15,360 p.)
edycja 2 sierpnia 2018 przez OdsetekGlupoty
I dlatego wszystkie zapytania do bazy zamykamy w try-catch. W zapytaniu do bazy masz ':imie'. Powinno być bez apostrofów. A na przyszłość, zamykaj zawsze zapytania do bazy w try-catch. Czyli najpierw try, potem prepare, bindValue i execute, a na końcu catch. Naprawdę przydatne i dla programisty i dla użytkownika jeśli coś pójdzie nie tak. I popraw formatowanie kodu, ułatwi to pracę i Tobie i forumowiczom którzy będą Ci kiedyś pomagać. :)
komentarz 2 sierpnia 2018 przez Michal93 Nowicjusz (190 p.)

Mówisz żebym try pisał w pliku sprawdzającym poprawność loginu i hasłą ?? To jest metoda Pana Mirosława, mi też ona się podoba, w innych kursach było tak jak mówisz ale skoro działa. Poprawiłem te imię i teraz zrobiłem tak jak mówisz, dalej nie działa. Baza danych się zgadza wiersze są poprawnie napisane w zmiennych i w select. Kod wyglą

if(isset($_POST['nick'])){
require_once "baza.php";


 $login = $_POST['nick'];
 $login = htmlentities($login, ENT_QUOTES, "UTF-8");
 $haslo = $_POST['haslo1'];
try {
        $rezultat = $polaczenie->prepare("SELECT * FROM dane WHERE imie=:imie");
        $rezultat->bindValue(':imie', $login, PDO::PARAM_STR);
        $rezultat->execute();
    
    
       
       $iluUrzytkownikow = $rezultat->rowCount();
       
       if($iluUrzytkownikow > 0)
       {
           $wiersz = $rezultat->fetch(PDO::FETCH_ASSOC);
           
           if(password_verify($haslo, $wiersz['haslo']))
           {
               $_SESSION['zalogowany'] = true;
               $_SESSION['nick'] = $wiersz['imie'];
               
               unset($_SESSION['blad']);
			   header('Location: admin.php');  
           
           
          }
           else 
				{
					$_SESSION['blad'] = '<span style="color:red">Nieprawidłowy login lub hasło!</span>';
					header('Location: index.php');
				}
           
      }
       else {
				
				$_SESSION['blad'] = '<span style="color:red">Nieprawidłowy login lub hasło!</span>';
				header('Location: index.php');
				
			}
      
   

} catch (PDOException $error){
    
    echo $error->getMessage();
      exit('Database error');
    
}
}
?>

da tak, w pliku baza.php nic nie mieniłem 

komentarz 2 sierpnia 2018 przez OdsetekGlupoty Pasjonat (15,360 p.)
Jakiś błąd się wyświetla? Ja nie będę za Ciebie rozwiązywał wszystkich problemów.

Spróbuj zrobić tak, że po każdej linijce kodu zapisujesz sobie echo z informacjami dla Ciebie co zostało zrobione. Gdy echo w pewnym momencie się nie wyświetli, to znaczy, że tam masz błąd.
komentarz 2 sierpnia 2018 przez Michal93 Nowicjusz (190 p.)
Okej dobry pomysł. Nie no masz racje, tylko właśnie chodzi o to że nie ma błędów tylko przekierowuje mnie do strony index.php i nie moge sie zalogowac, tak jak by przeierowanie nie działało

Podobne pytania

0 głosów
1 odpowiedź 241 wizyt
pytanie zadane 25 czerwca 2021 w JavaScript przez Grzegorz Mikina Dyskutant (8,060 p.)
+1 głos
2 odpowiedzi 137 wizyt
pytanie zadane 15 grudnia 2020 w JavaScript przez Hipolit Roszkowski Obywatel (1,480 p.)
0 głosów
2 odpowiedzi 232 wizyt
pytanie zadane 24 sierpnia 2018 w JavaScript przez Adamek185wp Obywatel (1,280 p.)

92,555 zapytań

141,402 odpowiedzi

319,540 komentarzy

61,938 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!

...