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

question-closed PHP error 500 - zapytanie do bazy danych

VPS Starter Arubacloud
0 głosów
125 wizyt
pytanie zadane 22 marca 2020 w PHP przez Peter Ja Początkujący (290 p.)
zamknięte 22 marca 2020 przez Peter Ja

Witam,

mam pewien problem co do małego API, które próbuję napisać. Ma ono wybierać z bazy tekst o podanym ID, i wg. ID użytkownika, który przesłał dany tekst znaleźć jego username. Po znalezieniu tekstu i username'a funkcja response() ma zakodować 2 dane w JSONa. Sama funkcja działa bez problemu. Gdy podam zły klucz / nie podam ID zakoduje się "invalid request", natomiast gdy ma wykonać się samo zapytanie do bazy strona pokazuje error 500. Albo ja jestem ślepy wink, albo jest to błąd hostingu lub nie wiem czego - w ten sam sposób wykonuję każde inne zapytanie na stronie i każda inna działa. Kopiuję kod i nic crying. Dodam, że nazwy kolumn były sprawdzane po 500 razy... Połączenie jest raczej dobre (mówię, łączy się w ten sposób każda inna stronka) - przechodzi przez ifa z błędem połączenia.
Dzięki!

PS. Pisałem tą samą stronkę (ale przez przypadek ją usunąłem) gdzieś z miesiąc temu i działała...

<?php
	header("Content-Type:application/json");
	require_once "connect.php";
	$connection = @new mysqli($host, $db_name, $db_user, $db_password);
	$connection->set_charset("utf8");
	$id = $_GET['id'];

	if((!empty($id)) && ($_GET['key'] == '<klucz here>'))
	{	
		if ($connection->connect_errno!=0)
		{
			$noteR = $connection->query("SELECT * FROM notes WHERE id='$id'");
			$noteD = $noteR->fetch_assoc();

			$note = $noteD["note"];
			$userId = $noteD["author"];

			$authoR = $connection->query("SELECT * FROM users WHERE id='$userId'");
			$authorD = $authorR->fetch_assoc();

			$author = $authorD["username"];

			if(empty($note))
			{
				response("Note Not Found", NULL);
			}
			else
			{
				response($note, $author);
			}
		}
		else
		{
			echo $connection->connect_errno;
		}
	}
	else
	{
		response("Invalid Request", NULL);
	}

	function response($note, $author)
	{
		$response['note'] = $note;
		$response['author'] = $author;

		$json_response = json_encode($response, JSON_UNESCAPED_UNICODE);
		echo $json_response;
	}
?>
komentarz zamknięcia: Rozwiązałem problem, dzięki!

1 odpowiedź

0 głosów
odpowiedź 22 marca 2020 przez Arkadiusz Waluk Ekspert (287,550 p.)

Nie widać w kodzie błędów składniowych, więc my też tego nie wiemy bez pełnej analizy tego. Może więc to coś z konfiguracją, może strukturą bazy, może jeszcze coś innego... Usuń @, bo ukrywanie ewentualnych błędów w niczym Ci nie pomoże. Włącz wyświetlanie wszystkich błędów PHP i zobacz co pokaże. Jeśli nic, to ustaw, aby mysqli na pewno wyrzucało wszystkie błędy: https://www.php.net/manual/en/mysqli-driver.report-mode.php

A tak przy okazji to nie masz żadnego zabezpieczenia przed sql injection z tego co widzę.

komentarz 22 marca 2020 przez Peter Ja Początkujący (290 p.)
Dzięki, poczytam i poprawię ;)

Podobne pytania

0 głosów
2 odpowiedzi 1,422 wizyt
pytanie zadane 31 sierpnia 2015 w PHP przez tytanik2011 Użytkownik (930 p.)
0 głosów
2 odpowiedzi 299 wizyt
pytanie zadane 12 sierpnia 2015 w SQL, bazy danych przez makoso Mądrala (7,380 p.)
0 głosów
1 odpowiedź 3,464 wizyt

92,454 zapytań

141,263 odpowiedzi

319,099 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...