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

Komentarze na stronie

VPS Starter Arubacloud
0 głosów
269 wizyt
pytanie zadane 23 kwietnia 2020 w PHP przez Farba Początkujący (440 p.)
edycja 26 kwietnia 2020 przez Farba

Mam kilka delikatnych problemów z systemem komentarzy na mojej stronie.

1. Komentarz najnowszy nie pokazuje się - rozwiązane (trzeba było dodać +1 do 0 w lini 36 (if($sprawdz->num_rows > 0+1)))

2. Komentarze na stronie pokazują się od najstarszego do najnowszego. - rozwiązane

3. Komentarz o max długości 100 txt dodaje się do bazy danych. Dłuższe nie dodają się. - rozwiązane

4. Komentarz który dodałem przykładowo o 19:55 w bazie danych zapisuje się jako 7:55. - rozwiązane (odpowiedź kolegi na dole)

5.  I jeszcze taki bardzo delikatny błąd czyli jeżeli zmienię jedną rzecz w css np. kolor tła na inny to pokazuje się od razu. Lecz jeżeli zmienię czcionkę na mojej stronie która ma 10000 txt to zmieni się dopiero po ponownym uruchomieniu komputera. Nie wiem czy da się to naprawić. - rozwiązane

Pracuję aktualnie nad tymi problemami. Jeżeli ktoś pomoże był bym wdzięczny.

1 odpowiedź

0 głosów
odpowiedź 23 kwietnia 2020 przez SzkolnyAdmin Szeryf (86,280 p.)
wybrane 25 kwietnia 2020 przez Farba
 
Najlepsza

"Talk is cheap. Show us the code."

Pokaż:

- strukturę tabeli bazy danych

- kod php odpowiedzialny za wstawianie danych do bazy

- kod php odpowiedzialny za pobieranie i wyświetlanie danych

 

komentarz 23 kwietnia 2020 przez Farba Początkujący (440 p.)

Wyslij.php :  (dodawanie komentarzy do bazy)

<?php
	
	if(!isset($_POST['autor']))
	{
		header('Location: index.php');
		exit();
	}
	
	$nick = $_POST['autor'];
	$tresc = $_POST['tresc'];
	
	if(strlen($nick) == 0 || strlen($tresc) == 0)
	{
		$_SESSION['blad'] = "Żadne pole nie może być puste";
		header('Location: index.php');
	}
	else
	{
		require_once('connect1.php');
	
		try
		{
			$polaczenie = new mysqli($host, $db_user, $db_password, $db_name);
			
			if($polaczenie->connect_errno !=0)
			{
				throw new Exceptopn(mysqli_connect_error());
			}
			else
			{
				$data = date("d-m-Y | h:i");
				
				if($polaczenie->query("INSERT INTO komentarze VALUE(NULL, '$tresc', '$nick', '$data', 0)"))
				{
					$_SESSION['wyslano'] = true;
					header('Location: index.php');
				}
				else
				{
					$_SESSION['blad'] = "Błąd podczas wysyłania komentarza";
					header('Location: index.php');
				}
				$polaczenie->close();
				
			}
		}
		catch(Exception $error)
		{
			echo "CONNECTION ERROR!";
		}
	}
?>

Connect1.php : (połączenie z bazą)

<?php

	$host = "localhost";
	$db_user = "root";
	$db_password = "";
	$db_name = "coments";
	
?>

index.php : (system pokazywania i dodawania komentarzy)

					<form action="wyslij.php" method="post">
						<input type="text" name="autor" placeholder="Imię i Nazwisko(opcjonalnie)"/></br>
						<textarea class="Treść_aktualności" type="text" name="tresc" placeholder="Treść"></textarea></br>
						<input type="submit" value="Dodaj"/>
						</form>
			<?php
				if(isset($_SESSION['blad']))
				{
					echo '<div style="color: red;">'.$_SESSION['blad'].'</div>';
					unset($_SESSION['blad']);
					'</br>';
				}
				
				if(isset($_SESSION['wyslano']))
				{
					echo '<div style="color: blue;">'.$_SESSION['wyslano'].'</div>';
					unset($_SESSION['wyslano']);
					'</br>';
				}
			?>
			<?php
				try
				{
					require_once("connect1.php");
					
					$polaczenie = new mysqli($host, $db_user, $db_password, $db_name);
					
					if($polaczenie->connect_errno != 0)
					{
						throw new Exception(mysqli_connect_error());
					}
					else
					{
						$sprawdz = $polaczenie->query("SELECT * FROM komentarze");
						
						if($sprawdz->num_rows > 0)
						{
							$num = $sprawdz->num_rows;
							
							for($i = 1; $i < $num; $i += 1)
							{
								if($komentarz = $polaczenie->query("SELECT * FROM komentarze WHERE id='$i'"))
								{
										$wiersz = $komentarz->fetch_assoc();
										
										if($wiersz['banned']==1)
										{
											continue;
										}
										
										echo '
										</br>
										<div class="komentarz">'
											.$wiersz['autor'].''
											.$wiersz['data'].'
											<br/>'.$wiersz['tresc'].'
											<a href="usun.php?id='.$i.'">
												Usuń
											</a>
										</div>
										</br>';
								}
							}
						}
						
						$polaczenie->close();
					}
				}
				catch(Excample $error)
				{
					echo "ERROR!";
				}
			?>

Wygląd bazy danych : 

https://ibb.co/P4sD2zt

1
komentarz 24 kwietnia 2020 przez SzkolnyAdmin Szeryf (86,280 p.)
Tak na szybko.

Ad.4. Zapis date("d-m-Y | h:i")  powoduje, że godzina jest wyświetlana w formacie 12-godzinnym. Poczytaj o formatach stosowanych w funkcji date. IMO lepiej w bazie danych ustawić pole daty dodania komentarza jako timestamp lub zastosować odpowiedni format, nie text.

Masz w kodzie literówki, np. Excample, Exceptopn  zamiast Exception.
komentarz 24 kwietnia 2020 przez Farba Początkujący (440 p.)
edycja 24 kwietnia 2020 przez Farba
Dzięki

Rozwiązaniem było : date("d-m-Y | H:i")

Podobne pytania

0 głosów
2 odpowiedzi 480 wizyt
pytanie zadane 6 lutego 2017 w PHP przez DxKKxD Użytkownik (560 p.)
0 głosów
1 odpowiedź 170 wizyt
pytanie zadane 7 października 2017 w Inne języki przez Bodziu Obywatel (1,250 p.)
0 głosów
1 odpowiedź 552 wizyt
pytanie zadane 14 października 2019 w PHP przez jared Gaduła (3,600 p.)

92,453 zapytań

141,262 odpowiedzi

319,088 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!

...