Diskuze: Bezpečnost kódu
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 10 zpráv z 10.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Doporučuji všechny proměnné které může uživatel nějakým způsobem ovlivňovat ošetřit funkcí htmlspecialchars.
$stranka=htmlspecialchars($_GET['stranka']);
Do první podmínky bych ještě přidal...
&& !empty($_GET['stranka']))
Pak by bylo ještě vhodné ošetřit zda požadovaný soubor existuje.
Ahoj,
podívej se na OWASP projekt ESAPI, to jsou knihovny pro validaci vstupních
dat, která je dostupná i pro PHP. Jinak validaci hodnot v byznys/aplikační
logice bys měl dělat taky, to za tebe bezpečnostní knihovna neudělá.
Petr
A mně zas přijdou obě odpovědi mimo mísu
htmlSpecialChars je tady úplně useless a podmínka isset stačí. Jelikož je
tazatel začátečník, pak řešit nějakou velkou security je trochu nad
rámec.
@kom72: Tady je cílem v podstatě jen to, aby se podle parmetru v URL
vložil správný soubor. Pokud parametr neexistuje, použije se "uvod" jako
default, OK. To ti zabrání errorům typu "notice: undefined index 'stranka' in
...".
Pak potřebuješ zamezit možnosti vložení jiného souboru, než které jsou
povolené (typická chyba při include $_GET["stranka"]). Ten regulární výraz
mi na to připadá OK.
Mám pocit, že include ti hodí notice, pokud daný soubor neexistuje. Osobně bych to raději pořešil funkcí file_exists().
Jinak se mi to zdá v pohodě.
Ja na svojej stranke to mam poriesene takto, neviem ake bezpecne to je, ale urcite kratsie ako tvoje riesenie
if (isset($_GET['page']))
{
$page = $_GET['page'];
if (file_exists('sub/' . $page . '.php'))
{
include('sub/' . $page . '.php');
}
else
include('sub/error404.php');
}
else
{
include('sub/home.php');
}
takhle se můžu dostat i k úplně jiným souborům, když ti do URL hodim "../"
vtedy by ti to malo vyhodit 404, ak sa budes pokusat nejaky otvorit nie?
Pokud ten soubor bude existovat, pak se prostě vloží když ti pak vyjde třeba
include "sub/../../../soubor.php";
tak je to jako bys měl jenom
include "../../soubor.php";
a najednou se ti do obsahu vloží soubor, který by se vůbec vložit neměl
(mimo složku sub).
Myslim, že v tomhle nepomůže ani .htaccess. Je tedy potřeba zamezit možnost
do toho parametru v URL vložit tečky a lomítka (nebo to prostě nějak
ošetřit, aby nešlo vložit nic mimo tu složku sub).
Sorry za palec dole (preklik) ...
Ta stranka a jej struktura je urobena tak, ze aj keby sa nieco take stalo, tak sa nic nestane, ale kazdopadne osetrim to nejako pre buducnost
Nespoléhej se na něco, co se může kdykoliv změnit pak se na to zapomene a je problém. Obecně je lepší vůbec nenechat možnost zajít do jiných adresářů
Zobrazeno 10 zpráv z 10.