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

Profil użytkownika, problem

Object Storage Arubacloud
0 głosów
125 wizyt
pytanie zadane 10 lutego 2017 w PHP przez tysiek Użytkownik (560 p.)

Witam,

Mam problem z PHP, a dokładniej z profilem użytkownika.

 $connect = mysqli_connect("localhost","xxx","xxx","xxx");
 
if (mysqli_connect_errno())
  {
  echo "MySQL: " . mysqli_connect_error();
  }
  
 if(isset($_GET['id'])) {
 $select=mysqli_query("SELECT * FROM uzytkownicy WHERE id='".$_GET['id']."'");
 if(!mysqli_num_rows($select)) { echo 'Ten użytkownik nie istnieje!!!'; } else {
 $user=mysqli_fetch_array($select);
 echo 'E-mail: '.$user['email'].'<br>';
 }
 }
  mysqli_close($sql);

I wyskakuje Ten użytkownik nie istnieje!!!, a wpisuje profil.php?id=1

1 odpowiedź

0 głosów
odpowiedź 10 lutego 2017 przez Assasz Nałogowiec (30,460 p.)
Popatrz dokładnie na apostrofy w zapytaniu SQL. Ono się nie wykonuje.
komentarz 10 lutego 2017 przez tysiek Użytkownik (560 p.)
No widzę, że jest źle. Nie mam pomysłu, aby to działało. Jak to zmienić?
komentarz 10 lutego 2017 przez Assasz Nałogowiec (30,460 p.)

Dobra, to by wyglądało mniej więcej tak:

$connect = mysqli_connect("localhost","xxx","xxx","xxx");
  
if (mysqli_connect_errno())
  {
  echo "MySQL: " . mysqli_connect_error();
  }

 if(isset($_GET['id'])) 
 {
	 $select=mysqli_query($connect, "SELECT * FROM uzytkownicy WHERE id='".$_GET['id']."'");
	 if(mysqli_num_rows($select)<1) 
	 	{ 
	 		echo 'Ten użytkownik nie istnieje!!!'; 
	 	} 
	 	else 
	 	{
			 $user=mysqli_fetch_array($select);
			 echo 'E-mail: '.$user['email'].'<br>';
		 }
 }
  mysqli_close($connect);

Poprawiłem wszystkie błędy, a trochę ich było (ale akurat nie z apostrofami, kolorowanie składni w poście mnie zmyliło). Czyli:

1. Niezdefiniowana zmienna $sql.

2. mysqli_query przyjmuje dwa parametry, pierwszy to połączenie z bazą, drugi to zapytanie.

3. mysqli_num_rows przyjmuje jako wynik liczbę wierszy, a nie wartość logiczną. Więc sprawdzanie, czy funkcja przyjmuje wartość false jest bez sensu (no chyba, że wystąpi jakiś błąd jak w tym wypadku, dlatego wyświetlił się komunikat o braku użytkownika)

To, że kod wygląda jak makaron i ogólnie jest słaby to już inna sprawa.

Podobne pytania

0 głosów
1 odpowiedź 136 wizyt
pytanie zadane 30 stycznia 2021 w Java przez jurek201 Nowicjusz (120 p.)
0 głosów
1 odpowiedź 183 wizyt
pytanie zadane 15 lutego 2018 w PHP przez Yashe Dyskutant (7,720 p.)

92,579 zapytań

141,432 odpowiedzi

319,663 komentarzy

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

...