LINUXSOFT.cz Přeskoč levou lištu

ARCHIV



   

> PHP (48) - Práce s binárními daty (BLOB)

Měla by se binární data ukládat do databáze, nebo ne? A jestliže ano, jak s tím pak pracovat v PHP?

22.9.2004 10:00 | Petr Zajíc | Články autora | přečteno 46805×

Tento díl seriálu jste si vyžádali ve svých e-mailových reakcích na předchozí články. Zaznamenal jsem několik dotazů, jak v PHP a MySQL pracovat s binárními daty.

Proč to nemám rád

Především, musím se přiznat, že taková řešení moc nepodporuji. Není mnoho pádných důvodů pro ukládání binárních dat do MySQL databází, jestliže tvoříte klasickou webovou aplikaci. Budete-li chtít ukládat do MySQL například sérii obrázků, měli byste vědět, že:

  • to je pomalé. Minimálně pomalejší o databázovou režii.
  • to zabere víc místa. MySQL musí mít uloženy informace nejen o samotném souboru, ale i některá metadata.
  • to většinou znamená celou řadu práce pro programátora navíc.

Abychom byli upřímní, může to mít i výhody. Přišel jsem na dvě:

  • Možná, že binární data v databázi budeme moci lépe zabezpečit, než kdyby byla na disku.
  • Do binárního pole v databázi můžeme uložit prakticky cokoliv. V jednom řádku dat to může být obrázek, v jiném třeba soubor obsahující hudbu.

Jestliže ale nemáte jinou možnost, nebo jestliže potřebujete ukládat binární data, může Vám MySQL sloužit.

Co udělat v databázi

V MySQL je pro uložení binárních dat použit sloupec typu BLOB (binary large object). Takže, pokud budete chtít definovat tabulku pro uložení obrázků s jedním sloupcem, můžete použít něco ve smyslu:

CREATE TABLE obrazky (id INT NOT NULL AUTO_INCREMENT ,
obrazek BLOB NOT NULL , PRIMARY KEY (id));

Jestliže máte definici tabulky hotovou, můžete do ní směle vložit data. Mějme například ve složce, z níž se skript spouští, uložen soubor test.jpg. V takovém případě jej můžete načíst pomocí funkce fread do proměnné a vložit do databáze. Jenže pozor: binární soubor může obsahovat kdeco, včetně například apostrofů a jiných znaků, které by při sestavování dotazu mohly databázi zmást. Kdyby se to stalo, uloží se náš obrázek porušený nebo se dokonce neuloží vůbec. Musíme tedy použít funkci addslashes, která vkládaná data před jejich uložením oescapuje. Celé to může vypadat následovně:

<?
  
// zde je include souboru s konstantami
  
mysql_connect(SQL_HOST, SQL_USERNAME, SQL_PASSWORD);
  
mysql_select_db(SQL_DBNAME);
  
$fp = fopen("test.jpg", "rb");
  
$binarydata = addslashes(fread($fp, filesize("test.jpg")));
  
mysql_query ("insert into obrazky (obrazek) values ('" . $binarydata . "')");
  
fclose($fp);
?>

Pozn.: Někteří tvrdí, že "úpravu" spočívající v přidání escape znaků pomocí funkce addslashes nepřežijí obrázky ve formátu jpeg. Sám jsem se s tím nesetkal. Kdyby Vás to nicméně potkalo, můžete data zakódovat například pomocí funkce base64_encode. Budou ale zabírat v databázi o třetinu místa více.

Zobrazování binárních dat

Jeden veliký problém spočívá v tom, že musíme vědět, s jakými binárními daty právě pracujeme, a musíme to sdělit prohlížeči. Takže, kdybychom měli zobrazovat obrázky uložené v tabulce podle předchozího příkladu, můžeme směle použít něco jako:

<?
  
// zde je include souboru s konstantami
  
mysql_connect(SQL_HOST, SQL_USERNAME, SQL_PASSWORD);
  
mysql_select_db(SQL_DBNAME);
  if (!isset(
$_GET["obrazek"])) die ("Nezadali jste číslo obrázku");
  
$vysledek = mysql_query ("SELECT * FROM obrazky where id=".$_GET["obrazek"]);
  if (!
mysql_num_rows($vysledek)==1) die ("Nemáme takový obrázek");
  
header("Content-Type: image/jpeg");
  
$row = mysql_fetch_assoc ($vysledek);
  echo
$row["obrazek"];
?>

Spustit skript (1) | Spustit skript (2)

přičemž řádek s voláním funkce header je nezbytný. Jinak totiž nebohý prohlížeč nepozná, co má s došlými binárními daty dělat.

Co když ale potřebujeme zobrazit nejen samotný obrázek, ale stránku, která bude obsahovat dejme tomu několik různých obrázků pocházejících z databáze? To je problém, protože v tom případě nemůžeme použít funkci header jako v předchozím případě. Máte zhruba tři možnosti:

  • Obrázky vyexportovat do souborů a použít je, jako by tam byly odjakživa (brr, pomalé).
  • Znásilnit funkce PHP pro práci s proudy a funkce pro práci s buffery a nějak to před odesláním binárně poslepovat (brr, složité)
  • Použít následující fintu:
<img src="48_show.php?obrazek=1"><br>
To je moje kočka ;-))<br>
<img src="48_show.php?obrazek=2"><br>
Neuvěřitelná podobnost mého kamaráda a agenta Smithe z Matrixu.<br>

Spustit skript

Opravdu to funguje a opravdu v tom není žádná záludnost. Prostě jsme jako zdroj obrázku nepoužili soubor jpg, ale soubor, který jej "nějak" generuje.

Závěr

Ukládání binárních dat do databáze je většinou jako technika kritizováno, ale někdy se to může hodit. Při vkládání dat používejte addslashes. Pozor, je nutné vědět, jakého typu jsou vkládaná data, pokud s nimi budete chtít pracovat pomocí PHP a zobrazovat je v prohlížeči.

Verze pro tisk

pridej.cz

 

DISKUZE

Nefunguje mi to 24.3.2005 14:46 Stanislav Levinsky
hlavička 9.4.2008 22:28 Dan Pelíšek
L Re: hlavička 10.4.2008 10:59 Aleš Hakl
Jednoducha galerie 5.7.2009 03:08 swosh
L Re: Jednoducha galerie 5.7.2009 05:04 Aleš Hakl
  L Re: Jednoducha galerie 5.7.2009 22:30 swosh
Kolik verzí obrázku potřebuji pro galerii? 10.2.2010 14:12 peedek
  |- Re: Kolik verzí obrázku potřebuji pro galerii? 10.2.2010 14:14 peedek
  L Re: Kolik verzí obrázku potřebuji pro galerii? 11.2.2010 19:18 Radim Kolář
    L Re: Kolik verzí obrázku potřebuji pro galerii? 12.2.2010 15:50 peedek
      L Re: Kolik verzí obrázku potřebuji pro galerii? 13.2.2010 00:17 Radim Kolář
        L Re: Kolik verzí obrázku potřebuji pro galerii? 14.2.2010 20:26 peedek




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

28.11.2018 23:56 /František Kučera
Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1

12.11.2018 21:28 /Redakce Linuxsoft.cz
22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář

6.11.2018 2:04 /František Kučera
Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář

4.10.2018 21:30 /Ondřej Čečák
LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář

18.9.2018 23:30 /František Kučera
Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář

9.9.2018 14:15 /Redakce Linuxsoft.cz
20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business. Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář

12.8.2018 16:58 /František Kučera
Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář

16.7.2018 1:05 /František Kučera
Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

31.7.2023 14:13 / Linda Graham
iPhone Services

30.11.2022 9:32 / Kyle McDermott
Hosting download unavailable

13.12.2018 10:57 / Jan Mareš
Re: zavináč

2.12.2018 23:56 / František Kučera
Sraz

5.10.2018 17:12 / Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2024) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze