PHP (skriptovací jazyk)

programovací jazyk

PHP (PHP: Hypertext Preprocessor) je populárny open source programovací jazyk, ktorý sa používa najmä na programovanie klient-server aplikácií (na strane servera) a pre vývoj dynamických webových stránok.

PHP

Druhmultiplatformný
Dátum vzniku8.6.1995
Použitiewebové stránky a aplikácie
Typová kontrolaslabá, dynamická
TvorcaRasmus Lerdorf, The PHP Development Team
Používané prípony.php .phtml .php4 .php3 .php5 .phps .phar

Medzi známe aplikácie založené na PHP patrí napríklad phpBB a MediaWiki, software, na ktorom beží Wikipédia. PHP je alternatívou k:

Všeobecný prehľad upraviť

PHP bolo inšpirované jazykmi podporujúcimi procedurálne programovanie. Najviac vlastností prebralo od jazyka C a jazyka Perl. V neskorších verziách bolo rozšírené o možnosť používať objekty.

Jedna zo zaujímavých vlastností PHP je, že umožňuje oveľa viac ako bežný skriptovací jazyk. Vďaka modulárnemu návrhu možno PHP používať aj na vývoj aplikácii s užívateľským rozhraním (GUI).

PHP dokáže spolupracovať s relačnými databázami, ako napríklad MySQL, Oracle, IBM DB2, Microsoft SQL Server, PostgreSQL alebo SQLite, pričom si stále zachováva jednoduchú a priamočiaru syntax. PHP beží na takmer všetkých najrozšírenejších operačných systémoch, vrátane UNIXu, Linuxu, Windows či Mac OS X. Spolupracuje s najrozšírenejšími webovými servermi.

Architektúra Linux-Apache-MySQL-PHP (zaužívaná skratka LAMP) a takisto Windows-Apache-MySQL-PHP (WAMP) sa stali veľmi obľúbenými v internetovom odvetví.

História upraviť

PHP bolo pôvodne navrhnuté ako niekoľko skriptov v jazyku Perl, neskôr prepísaných do jazyka C. Autorom bol Rasmus Lerdorf v roku 1994. O rok neskôr svoje skripty zverejnil pod názvom "Personal Home Page Tools". Kombináciou s ďalším jeho programom Form Interpreter vzniklo PHP/FI. Zeev Suraski a Andi Gutmans, dvaja izraelskí vývojári prepísali syntaktický analyzátor (parser) v roku 1997 na novšiu verziu, ktorá sa stala základom PHP 3. Krátko po zverejnení verzie PHP 3 bola spustená aj oficiálna stránka. V roku 1999 sa Suraski a Gutmans opäť pustili do prepísania jadra, už pod názvom Zend engine. Založili spoločnosť Zend Technologies, ktorá sa odvtedy podieľa na ďalšom vývoji PHP. V máji 2000 bolo vydané PHP 4, ktorého jadro tvoril nový Zend Engine 1.0. 13. júla 2004 bola vydaná verzia PHP 5, s jadrom „Zend Engine II“, obsahujúca nové rysy ako napr. vylepšená podpora objektovo orientovaného programovania, PHP Data Objects extension a ďalšie.

Použitie upraviť

PHP je skriptovací jazyk[1], ktorý je špeciálne navrhnutý na tvorbu web stránok bežiacich na webovom serveri. Všetok PHP kód je vykonávaný pomocou PHP runtime, aby dynamicky vytvoril obsah na webovej stránke.[2] Taktiež môže byť využitý na skriptovanie z príkazového riadku alebo klientovo orientované aplikácie s grafickým rozhraním. PHP môže byť nasadené na väčšine Webových serverov, operačných systémov a platformách a môže sa používať v spojení s mnohými relačnými databázami. Mnoho webhostingov ponúka podporu PHP pre svojich klientov. PHP je zadarmo dostupné a PHP Group poskytuje úplný zdrojový kód pre používateľov, aby ho mohli dotvárať, meniť a rozširovať pre ich vlastné použitie.[3] PHP sa primárne správa ako filter[4], ktorý má na vstupe súbor, alebo prúd dát obsahujúci text a/alebo PHP inštrukcie a na výstupe prúd dát najčastejšie vo forme HTML. Od PHP verzie 4 PHP parser kompiluje vstup aby vyprodukoval bajt kód pre spracovanie pomocou Zend Engine, ktorý poskytuje zvýšený výkon v porovnaní s jeho interpretermi v minulosti.[5] Aj keď PHP bolo pôvodne vytvorené na tvorbu dynamických webových stránok, v súčasnosti sa primárne zameriava na skriptovanie na strane servera[6] a je podobné ostatným serverovo orientovaným skriptovacím jazykom, ktoré klientovi poskytujú dynamický obsah z webového servera. Medzi tieto jazyky patrí napríklad ASP .NET od spoločnosti Microsoft, JavaServer Pages[7] od Sun Microsystems alebo mod_perl. PHP pritiahlo produkciu mnohých frameworkov, ktoré poskytujú stavebné bloky a návrh štruktúry pre podporu rýchleho vývoja aplikácií. Niektoré ako CakePHP, Symfony, CodeIgniter, Yii Framework a Zend Framework ponúkajú vlastnosti podobné iným frameworkom pre webové aplikácie. LAMP architektúra sa stala populárnou vo webovom priemysle ako spôsob vývoja webových aplikácií. Písmeno „P“ v tomto balíku bežne zastáva PHP po boku s Linux, Apache a MySQL, avšak môže odkazovať aj na Python, Perl, alebo kombináciu všetkých troch. Podobné balíky sú taktiež dostupné pre Windows a OS X, pričom ich názvy sú WAMP a MAMP, kde prvé písmená reprezentujú operačný systém. Hoci PHP a Apache sú súčasťou Mac OS X základnej inštalácie, používatelia týchto balíkov vyhľadávajú jednoduchšiu inštaláciu, ktorá je jednoduchšie aktualizovaná. Od apríla 2007 viac ako 20 miliónov internetových domén malo webový servis hostovaný na serveroch s inštalovaným PHP a mod_php bolo zaznamenané ako najpopulárnejší Apache HTTP Serverový modul.[8] PHP je používané ako serverovo orientovaný programovací jazyk na 75 % zo všetkých web stránok, ktorých serverovo orientovaný programovací jazyk je známy[9], a PHP je najpoužívanejší open source softvér v spoločnostiach.[9] Množina systémov na správu webového obsahu napísané v PHP zahŕňa MediaWiki, Joomla, eZ Publish, SilverStripe, WordPress, Drupal a Moodle. Všetky webové stránky vytvorené pomocou týchto nástrojov sú napísané v PHP, zahŕňajúc požívateľskú časť Wikipédie, Facebook a Digg.

Bezpečnosť upraviť

Okolo 30 % všetkých zraniteľností zaznamenaných v National Vulnerability Database sú spojené s PHP.[10] Tieto zraniteľnosti sú spôsobené nedodržaním pravidiel praktického programovania. Technické chyby samotného jazyka alebo jeho základných knižníc nie sú také časté (okolo 1 % zo všetkých chýb v roku 2008).[11][12] Keďže programátori robia chyby, niektoré jazyky obsahujú kontrolu chýb na automatické zisťovanie nedostatočnej validácie vstupu, ktorá vedie k mnohým problémom. Takáto funkcia je vyvíjaná aj pre PHP,[13] ale jej zahrnutie a vydanie bolo v minulosti niekoľkokrát zamietnuté.[14][15] Existujú však pokročilé ochranné záplaty ako napríklad Suhosin a Hardening-Patch, ktoré sú špeciálne navrhnuté pre prostredia webhostingu.[16] PHPIDS pridáva bezpečnosť ľubovoľnej PHP aplikácii pre ochranu proti intruze. PHPIDS deteguje útoky založené na cross-site scripting (XSS), SQL injection, header injection, directory traversal, spúšťanie vzdialených súborov, remote file inclusion, a denial-of-service (DoS).

Optimalizácia rýchlosti upraviť

Zdrojový kód PHP je skompilovaný za behu na vnútorný formát, ktorý môže byť vykonaný prostredníctvom PHP engine.[17][18] Aby sa urýchlil čas vykonávania a nemusel sa kompilovať zdrojový kód vždy keď sa pristupuje k web stránke, môžu byť PHP skripty taktiež nasadené v spustiteľnom formáte použitím PHP kompilera. Optimalizátory kódu sú zamerané na vylepšenie výkonu skompilovaného kódu redukovaním jeho veľkosti, odstránením nadbytočných inštrukcií a vykonávaním iných zmien, ktoré môžu znížiť vykonávací čas. Pri PHP sú často príležitosti na optimalizáciu kódu.[19] Príkladom optimalizátora kódu je PHP rozšírenie eAccelerator. Ďalším prístupom k redukovaniu kompilačného zaťaženia pre PHP servery je použitie opcode cache. Opcode cache funguje na základe odchytávania skompilovanej formy PHP skriptu v zdieľanej pamäti aby predchádzala nadmernému parsovaniu a kompilovaniu kódu pri každom spustení skriptu. Aby sa zaručila najväčšia efektivita opcode caching a optimalizácia kódu môžu byť skombinované, keďže modifikácie sú vzájomne nezávislé (sú vykonávané v rozdielnych častiach kompilácie).

Zdroje upraviť

PHP obsahuje free a open source knižnice s jadrom. PHP je v podstate systém uvedomujúci si internet so zabudovanými modulmi pre pristupovanie k serverom s protokolmi pre prenos dát (FTP), mnohými databázovými servermi, zabudovanými SQL knižnicami ako napríklad PostgreSQL, MySQL, Microsoft SQL Server a SQLite, LDAP servery, a iné. Mnohé funkcie príbuzné programátorom v jazyku C, ako napríklad stdio rodina, sú prístupné aj v jadre PHP.[20] PHP sprístupňuje vývojárom písať doplnky v C pre pridanie funkcionality do jazyka. Tieto doplnky môžu byť skompilované do PHP alebo načítané dynamicky počas behu. Existujú doplnky pre podporu Windows API, manažment procesov na operačných systémoch založených na Unix-e, viacbytové reťazce (Unicode), cURL a niekoľko populárnych komprimovacích formátov. Iné funkcie obsahujúce integráciu s IRC, dynamické generovanie obrázkov a AdobeFlash obsahu a dokonca syntézu reči. Základné funkcie jazyka ako tie zaoberajúce sa reťazcami a poľami sú taktiež implementované ako doplnok.[21] PHP komunitná doplnková knižnica (PHP Extension Community Library PECL) je súhrn doplnkov pre PHP. [22] Zend poskytuje certifikačnú skúšku pre programátorov, vďaka ktorej sa môžu stať certifikovanými PHP vývojármi.

Syntax upraviť

PHP spracuje len kód ohraničený špeciálnymi tagmi, ostatný text bez zmeny odovzdá na výstup. Najvšeobecnejšie takto používané tagy sú <?php a ?>. Použiť sa však dá aj <script language="php"> a </script>, takisto skrátená forma <?, alebo <?= (na výpis reťazca, alebo premennej) a ?>, prípadne ASP-style tagy <%, <%= a %>. V prípade, že skript obsahuje skrátené formy, stáva sa menej prenosným, pretože ich rozoznávanie je možné v PHP konfigurácií zakázať. Zmyslom týchto tagov je oddeliť kód priamo spracúvaný PHP od zvyšného kódu.
Názvy premenných začínajú symbolom $ a samotné premenné nemusia mať dopredu definovaný typ. Na rozdiel od názvov funkcií a tried, v názvoch premenných sa rozlišujú veľké a malé písmená. PHP interpretuje medzeru, tabulátor a nový riadok ako biele znaky, teda kdekoľvek v kóde nezáleží na ich počte, ani poradí (samozrejme výnimkou je vnútro textového reťazca).
V PHP existujú 3 druhy komentárov:

  • /* ... */ na označenie blokového komentáru.
  • // ... na označenie jednoriadkového komentáru.
  • # ... na označenie jednoriadkového komentáru.

Syntaxou a kľúčovými slovami pripomína PHP jazyk C a jazyky z neho odvodené. Podmienený príkaz if, cykly for a while a návratové hodnoty funkcií sú syntakticky veľmi blízke jazykom ako C, C++, Java, alebo Perl.

Dátové typy upraviť

PHP ukladá celé čísla v rozsahu závislom od platformy (64 alebo 32 bitov) ako celé číslo so znamienkom ekvivalentne k typu long v jazyku C. Celé čísla bez znamienka sú v istých situáciách konvertované na hodnoty so znamienkom, čím sa odlišuje od iných programovacích jazykov.[23] Premenné typu celé čísla môžu mať určené používanie desiatkovej, osmičkovej a šestnástkovej notácie. Desatinné čísla sú taktiež zoradené podľa rozsahu závislého od platformy. Môžu používať notáciu desatinných čísel, alebo dve formy vedeckej notácie.[24] PHP má prirodzený booleovský typ, ktorý je podobný prirodzenému booleovskému typu v Jave a C++. Pri použití booleovskej konverzie pravidiel sú nenulové hodnoty interpretované ako pravda a nula je interpretovaná ako nepravda tak ako aj v Perl-e a C++. Prázdny (null) dátový typ je reprezentovaný ako premenná, ktorá nemá hodnotu. Jej jediná hodnota, ktorú môže nadobudnúť je NULL. Premenné typu „resource“ reprezentujú odkazy na prostriedky z externých zdrojov. Tieto sa zvyčajne vytvárajú funkciami z konkrétneho doplnku a môžu byť spracované iba funkciami z rovnakého doplnku. Príkladom môžu byť súbory, obrázky a databázové zdroje. Polia môžu obsahovať elementy hocakého typu, ktorý PHP dokáže spracovať, vrátane zdrojov, objektov a taktiež aj ďalších polí. Poradie je zachované v listoch hodnôt a v hashoch s hodnotami a kľúčmi, pričom sa môžu navzájom prelínať. PHP taktiež podporuje reťazce, ktoré môžu byť použité s jednoduchými úvodzovkami, dvojitými úvodzovkami, nowdoc alebo heredoc syntaxou.[25] Štandardná PHP knižnica sa pokúša riešiť bežné problémy a implementuje efektívne rozhrania pre dátové prístupy a triedy.[26]

Objekty upraviť

Základná funkcionalita objektovo orientovaného programovania bola pridaná v PHP 3 a vylepšená v PHP 4. Zaobchádzanie s objektmi bolo kompletne prepísané v PHP 5, keď bolo zároveň rozšírené o nové funkcie a vylepšené z hľadiska výkonnosti. V predošlých verziách PHP bolo k objektom pristupované ako k hodnotovým typom.[27] Nedostatkom tejto metódy bolo to, že celý objekt bol skopírovaný, keď bola hodnota priradená, alebo posunutá ako parameter nejakej metóde. V novom prístupe sú objekty odkazované podľa rukoväte a nie podľa hodnoty. PHP 5 predstavilo súkromné a chránené premenné a metódy objektu, spolu s abstraktnými triedami, konečnými triedami, abstraktnými metódami a konečnými metódami. Taktiež predstavilo štandardný spôsob deklarovania konštruktorov a deštruktorov podobných ako v iných objektovo orientovaných jazykoch ako napríklad C++ a aj štandardný model spracovávania chyby. Okrem toho PHP 5 pridalo rozhrania a povolilo implementáciu viacerých rozhraní. Existujú špeciálne rozhrania, ktoré objektom dovoľujú interakciu so systémom runtime. Objekty implementujúce prístup k poľu môžu byť použité so syntaxou poľa a objekty implementujúce iteráciu alebo agregáciu iterácie môžu byť použité s konštrukciou foreach. Neexistuje žiadna funkcia virtuálnych tabuliek v jadre, takže statické premenné sú počas kompilácie späté s menom namiesto s referenciou.[28] Ak vývojár vytvorí kópiu objektu pomocou rezervovaného slova clone, Zend engine skontroluje, či bola definovaná metóda __clone() alebo nie. Ak nie je tak sa zavolá predvolená metóda __clone(), ktorá skopíruje vlastnosti objektu. Ak je metóda __clone() definovaná, tak ona bude zodpovedná za nastavenie potrebných vlastností vo vytvorenom objekte. Pre pohodlie, jadro zaobstaráva funkciu, ktorá importuje vlastnosti zdrojového objektu, takže programátor môže začať s úplnou kópiou zdrojového objektu a iba nahradí vlastnosti, ktoré potrebuje zmeniť.[29]

Ukážky kódu upraviť

Prvý príklad zobrazí text „Ahoj svet!“:

    <?php
      echo "Ahoj svet!\n";
    ?>

Druhý príklad vypočíta preponu pomocou Pytagorovej vety:

    <?php
      $strana_a = 3;                          // strana a - premenná
      $strana_b = 4;                          // strana b - premenná
      $strana_c = hypot($strana_a,$strana_b); // výpočet strany c
      echo $strana_c;                         // výpis dĺžky strany c do tela stránky
    ?>

Tretí príklad ukazuje kombináciu PHP s HTML:

    <p>Práve sa píše rok <strong><?php echo Date("Y"); ?></strong>.</p>
    alebo
    <?php echo "<p align=\"center\">Príklad 3. bol pridaný v roku 2006.</p>"; ?>
    novšie sa používa verzia echo s ''; ktorá dovoľuje tagy bez zbytočných \ znakov, napríklad
    <?php echo '<p align="center">Príklad 3. bol pridaný v roku 2006.</p>'; ?>

Referencie upraviť

  1. Laravel vs PHP: Dissecting The Backend Frameworks in Detail! | Simform [online]. 2021-02-15, [cit. 2021-08-23]. Dostupné online. (po anglicky)
  2. PHP Manual Image Processing and GD; [online]. php.net, [cit. 2011-04-09]. Dostupné online.
  3. Embedding PHP in HTML [online]. O'Reilly, 2001-05-03, [cit. 2008-02-25]. Dostupné online. Archivované 2008-02-19 z originálu.
  4. Archivovaná kópia [online]. [Cit. 2013-05-31]. Dostupné online. Archivované 2008-06-11 z originálu.
  5. PHP and MySQL [online]. University of Alabama, [cit. 2008-02-25]. Dostupné online. Archivované 2008-02-28 z originálu.
  6. PHP Server-Side Scripting Language [online]. Indiana University, 2007-04-04, [cit. 2008-02-25]. Dostupné online. Archivované 2016-01-21 z originálu.
  7. JavaServer Pages Technology — JavaServer Pages Comparing Methods for Server-Side Dynamic Content White Paper [online]. Sun Microsystems, [cit. 2008-02-25]. Dostupné online.
  8. PHP: PHP Usage Stats [online]. SecuritySpace, 2007-04-01, [cit. 2008-02-24]. Dostupné online.
  9. a b Usage of server-side programming languages for websites [online]. W3Techs, 2010-10-29, [cit. 2010-10-29]. Dostupné online.
  10. PHP-related vulnerabilities on the National Vulnerability Database [online]. [Cit. 2012-07-05]. Dostupné online.
  11. Security and... Driving? (and Hiring) [online]. Sean Coates, [cit. 2009-07-29]. Dostupné online.
  12. Computerworlduk.com, Interview: Ivo Jansch, February 26, 2008
  13. PHP Taint Mode RFC [online]. . Dostupné online.
  14. Developer Meeting Notes, Nov. 2005 [online]. . Dostupné online.
  15. Taint mode decision, November 2007 [online]. [Cit. 2013-05-31]. Dostupné online. Archivované 2009-02-26 z originálu.
  16. Hardened-PHP Project [online]. 2008-08-15. Dostupné online.
  17. How do computer languages work? [online]. [Cit. 2009-11-04]. Dostupné online. Archivované 2011-07-16 z originálu.
  18. (Gilmore 2006)
  19. PHP Accelerator 1.2 (page 3, Code Optimisation) [online]. Nick Lindridge, [cit. 2008-03-28]. Dostupné online. Archivované 2008-05-14 z originálu.
  20. PHP Function List [online]. The PHP Group, [cit. 2008-02-25]. Dostupné online.
  21. Cross Reference: /PHP_5_4/ext/standard/
  22. Developing Custom PHP Extensions [online]. devnewz, 2002-09-09, [cit. 2008-02-25]. Dostupné online. Archivované 2008-02-18 z originálu.
  23. Integers in PHP, running with scissors, and portability [online]. MySQL Performance Blog, March 27, 2007, [cit. 2007-03-28]. Dostupné online.
  24. Types [online]. The PHP Group, [cit. 2008-03-16]. Dostupné online.
  25. Strings [online]. The PHP Group, [cit. 2008-03-21]. Dostupné online.
  26. SPL — StandardPHPLibrary [online]. PHP.net, March 16, 2009, [cit. 2009-03-16]. Dostupné online.
  27. PHP 5 Object References [online]. mjtsai, [cit. 2008-03-16]. Dostupné online.
  28. Classes and Objects (PHP 5) [online]. The PHP Group, [cit. 2008-03-16]. Dostupné online.
  29. Object cloning [online]. The PHP Group, [cit. 2008-03-16]. Dostupné online.

Externé odkazy upraviť