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

Wrzucenie plików i tekstu do bazy MYSQL jedną funkcją

Hosting forpsi easy 1 pln
0 głosów
154 wizyt
pytanie zadane 13 lutego w PHP przez zbiku25 Bywalec (2,940 p.)

W ramach jednego formularza chcę przesłać do bazy 3 pola tekstowe, jedno zdjęcie i 1 plik. Zrobiłem tak jak poniżej - używam do tego 2 odrębnych metod na klasie obiekcie sheet.

Zastanawiam się czy jest to optymalne rozwiązanie... być może dobre praktyki są inne (można wykorzystać jedną metodę?) - prośba o sugestię od bardziej doświadczonych ode mnie:)

Oczywiście odrębnie zaprogramuje sobie przeniesienie pliku z folderu tymczasowego do docelowego (to wiem jak zrobić)

Mój kod

index.php

<?php

include("classes/classes.php");

if( $_SERVER['REQUEST_METHOD']=="POST")
{
	$sheet = new Sheets();
	$result1 = $sheet->insert_data($_POST);
	$result1 = $sheet->insert_files($_FILES);
	
}


?>

.... i dalej formularz

<form method="post" enctype="multipart/form-data">
Author<br>
<input type="text" name="author"><br>
Title<br>
<input type="text" name="title"><br>
Tonation<br>
<input type="text" name="tonation"><br>
Image<br>
<input type="file" name="image"><br>
File<br>
<input type="file" name="file"><br><br>

<input type="submit">
</form>

plik z klasą:

class Sheets
{
	public function insert_data($data)
	{
		$author = $data['author'];
		$title = $data['title'];
		$tonation = $data['tonation'];

		$query = "INSERT INTO sheets(author, title, tonation) VALUES('$author', '$title', '$tonation')";
		
		$DB = new Database;
		$DB->save($query);
		
	}
	
		public function insert_files($data)
	{

		$images = $data['image']['tmp_name'];
		$file = $data['file']['tmp_name'];
		
		$query = "INSERT INTO sheets (images, file) VALUES ('$images', '$file')";
		
		$DB = new Database;
		$DB->save($query);
		
	}
}

 

3 odpowiedzi

0 głosów
odpowiedź 13 lutego przez zbiku25 Bywalec (2,940 p.)

właśnie się zorientowałem, że to musi być jedna funkcja, bo w przypadku dwóch są dodawane dwa rekordy w bazie....indecision

Pytanie zatem jak połączyć dane z $_FILES i $_POST w jednym zapytaniu....

0 głosów
odpowiedź 13 lutego przez charlieg Początkujący (280 p.)
hejka ja bym to zalatwil ze przypisal bym sobie atrybut name do inputa i nie bawil bym sie w tworzenie obiektu i funkcji tylko za pomoca action przeniosl wykonanie skryptu do osonego pliku dla czytelnosci teraz uzyl bym metody isset przyjmujaca wartosc z atrybutu name ---> submita ew nad ta instrukcja warunkowa funkcje i ich wykonanie kiedy spelniony jest warunek.
komentarz 13 lutego przez zbiku25 Bywalec (2,940 p.)
hej, dzięki za propozycję. Rzeczywiście można to zrobić w osobnym pliku, jednak robię to zadanie bardziej dla nauki programowania obiektowego niż znalezienia najprostszego rozwiązania stąd zależy mi na nauczeniu się sposobu jak to zrobić obiektowo :)
0 głosów
odpowiedź 13 lutego przez zbiku25 Bywalec (2,940 p.)

OK znalazłem działające rozwiązanie - wystarczy w metodzie dwie zmienne

public function insert_data($data, $files)

i później przy wywołaniu podać:

objekt->insert_data($_POST, $_FILES)

Jeżeli ktoś widzi lepsze rozwiązanie do będę wdzięczny :)

Podobne pytania

+1 głos
1 odpowiedź 1,549 wizyt
pytanie zadane 6 września 2015 w PHP przez tytanik2011 Użytkownik (930 p.)
0 głosów
1 odpowiedź 378 wizyt
pytanie zadane 20 czerwca 2020 w PHP przez Bakkit Dyskutant (7,600 p.)
0 głosów
1 odpowiedź 165 wizyt
pytanie zadane 19 stycznia 2019 w PHP przez Patryk Kania Początkujący (310 p.)

92,123 zapytań

140,784 odpowiedzi

317,794 komentarzy

61,445 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 1468p. - Łukasz Eckert
  2. 1444p. - Dawid128
  3. 1430p. - CC PL
  4. 1419p. - rafalszastok
  5. 1418p. - Marcin Putra
  6. 1362p. - rucin93
  7. 1351p. - sefirek
  8. 1275p. - Mikbac
  9. 1260p. - TheLukaszNs
  10. 1197p. - Adrian Wieprzkowicz
  11. 1144p. - Michal Drewniak
  12. 1109p. - adrian17
  13. 1078p. - Eryk Andrzejewski
  14. 1063p. - nidomika
  15. 1061p. - Anonim 3447134
Szczegóły i pełne wyniki

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.

Uwaga - w dniach od 02.12 do 08.12 trwają Mikołajki (książki drukowane mają rabat -35%, ebooki do -45%). Zaś dodatkowy, specjalny kod zniżkowy: HELMIKOLAJ-10 dla naszych Widzów zapewni Wam oszczędność -10zł dla zamówień powyżej 70zł! Warto korzystać!

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!

...