|
|||||||||||||||||||||||||||||||||||||||||||||||
Menu
Distributions (131)
bootable [55]
commercial [7] no-commercial [42] unclassified [20] [7]
Software (10844)
|
HtaccessČlánek pojednávající o konfiguračním souboru .htaccess. Najdete zde i několik příkladů užití.
.htaccessCo je to?Jedná se o serverový konfigurační soubor, který umožňuje upravovat některé funkce serveru. Zpravidla funguje v místě, kde administrátor serveru dává možnost uživateli, který daný server využívá, nastavit si určité funkce k obrazu svému bez nutnosti o to žádat správce. Administrátorovi se tedy ušetří mnoho práce s přepisováním konfiguračního souboru na serveru. Do .htaccess se píší příkazy pro server, pokud vás zajímají jenom tyto příkazy, některé z nich si uvádíme zde. Htaccess je využíván například serverem Apache a v tomto článku slovem server mám namysli právě Apache. Rozsah funkčnostiPokud .htaccess na serveru používáte, je dobré si uvědomit, že nastavení v něm uvedené platí pro adresář, ve kterém se nachází a pro všechny podadresáře. Tedy pokud budete chtít zakázat přístup z určité IP na celý web umístíte .htaccess do nejvrchnějšího (root) adresáře, ve kterém máte uložené stránky. Chcete-li změnit nastavení, které bylo zděděno z nadřazeného adresáře, musíte vytvořit v tom daném adresáři nový .htaccess a nastavit v něm co chcete změnit. Jak jej vytvořitNejprve se ujistěte, že na vašem serveru je .htaccess povolen, pokud ne, tak kontaktujte správce. Jste-li správcem Vy, je tu pro vás návod pro Linux (konkrétně jsem jej zkoušel na Ubuntu). Jinak můžete tuto pasáž přeskočit. Jako root otevřete soubor default v adresáři /etc/apache2/sites-available. sudo gedit /etc/apache2/sites-available/default
Tento příkaz po zadání do terminálu otevře soubor default v programu gedit (pro jiný program stačí přepsat gedit) jako správce. Poté najdete tuto část:
A přepište řádek AllowOverride None na AllowOverride all. Soubor uložíte a pak již stačí jen server restartovat: sudo /etc/init.d/apache2 restart
VytvořeníVytvoření tohoto souboru by na Linux/Unix systémech neměl být žádný problém. Stačí normálně vytvořit .htaccess soubor. Tečka na začátku značí v Linux/Unix systémech skrytý soubor, že .htaccess nemá příponu, není zde žádný problém. Ve Windows by vytvoření však již problém mohl být, potom musíte při vytváření souboru napsat před a za uvozovky, tedy: ".htaccess". PříkladyKomentářePro zapsání komentářů, tedy textu, který má server ignorovat se užívá značky #: # Já jsem komentář
Povolení / zakázání IPChcete-li omezit přístup určitému IP nebo všem .htaccess je na to výborný nástroj. Jak je psáno výše, tak záleží kam umístíte tento soubor. Předpokládejme, že chceme omezit přístup na celý web, proto uložíme .htaccess do nejvyššího adresáře a napíšeme: Zákaz přístupu pro všechny deny from all
Jen snad pro jistotu, nemusíte se bát, že vám toto blokne přístup na FTP. Zákaz přístupu pro určitou IP deny from 116.203.134.223
Pokud chcete blokovat určitá IP, která například začínají na 116.203 tak stačí zadat kód níže a server zablokuje všechny takovéto adresy. deny from 116.203
Povolení přístupu jen pro určitou IP
deny from all
Nejprve jsme zakázali přístup všem, a poté jsme povolili přístup pro adresu 116.203.134.223. Chybové stránkyJiž jste určitě zaznamenali, že některé stránky mají vlastní chybovou stránku. Například pokud není stránka nalezena (404), tak se zobrazí místo standardní stránky stránka vlastní. Funguje to pomocí ErrorDocument. Za ErrorDocument se píše číslo chyby, za číslo následuje cesta k souboru, který se má uživateli zobrazit (také místo cesty lze napsat text bez mezer). Například takto: ErrorDocument 404 / 404.html
Lehký přehled chybových stránek: 403 – Forbidden / Zakázáno – server zakázal přístup Samozřejmě existuje mnoho dalších chybových hlášení (400-414, 500, 501, atd.), ale tyto by mohly nenáročným stačit. Výchozí stránka adresářeJako výchozí stránka je na drtivé většině serverů nastavený index. Samozřejmě se díky .htaccess nemusíte omezovat jen na základní nastavení a udělat si to podle svého, k tomu vám pomůže DirectoryIndex. DirectoryIndex prvni.php první.html index.php index.html
Tento řádek říká serveru, že má vzít jako výchozí stránku první.php, pokud není, tak první.html a takto pokračuje dále, priorita je tedy zleva. Pochopitelně můžete zadat jenom jednu výchozí stránku. Výpis adresářeTento bod dá se říci navazuje na ten předešlý (Výchozí stránka adresáře), pokud nebyla žádná stránka nalezena může server zobrazit výpis adresáře, to můžete povolit/zakázat pomocí Options Indexes. Dáte-li před Indexes - zakážete zobrazení adresáře a pomocí + povolíte.
Povolí Mod_rewriteMod_rewrite se používá na podstrkování nebo přesměrování URL. Rozdíl mezi podstrčením a přesměrováním je takový, že u přesměrování uživatel ví o změně adresy. U podstrčení server neinformuje uživatele a rovnou odesílá podstrčený dokument. My si tu ukážeme jak pomocí toho udělat tzv. hezké URL a opět si uvedeme příklad. Chceme docílit, abychom mohli používat nějaké takovéto URL:
A server to chápal takto: Nejprve tedy povolíme Mod_rewrite: RewriteEngine on
Potom zadáme podmínku, kterou musí splňovat URL (část URL bez http://priklad.com): RewriteCond %{REQUEST_URI} clanek(.*)$
Část clanek(.*)$ využívá tzv. regulární výrazy. Další krok je již podstrčení: RewriteRule clanek(.*)$ /index.php?id=$1 [L]
$1 je proměnná, která odpovídá závorkám (.*). Výsledek tedy bude vypadat nějak takto: RewriteEngine on
Nechcete-li podstrkávat, ale přesměrovávat změňte poslední řádek na: RewriteRule clanek(.*)$ /index.php?id=$1 [R, L]
R značí přesměrování s kódem 302 - Moved Temporarily „Přesunuto dočasně“ Pomocí .htaccess se dá dělat spoustu věcí, doufám, že jsem zde uvedl alespoň ty nejdůležitější.
|
Szukanie oprogramowania
|
|||||||||||||||||||||||||||||||||||||||||||||
©Pavel Kysilka - 2003-2024 | maillinuxsoft.cz | Design: www.megadesign.cz |