- Kezdőlap
-
Domain Regisztráció
-
Domain Regisztráció
ÚJ Domain regisztráció.
Csak add meg a választott domain neveket.Ha még szabad, az adataid megadásával azonnal BIZTONSÁGBA helyeztük neked. -
Domain Ellenőrzés
Egy gombnyomással akár 100 domain név foglaltságát is ellenőrizheted. Szabad domaineket pedig megveheted.
-
Ingyen Domain
Minden amit tudni szeretnél az ingyen domain nevekről. Megmutatjuk a teljes igazságot szépítés nélkül.
-
Domain + Honlap Gyorsan
Vevőmágnes, díjnyertes honlap, hogy ne legyél kiszolgáltatva egy fejlesztőnek se. Előre kalkulálható befektetés.
-
Domain Regisztráció
-
Tárhelyek
-
Google Barát Tárhelyek
Tárhely rendelés: Imádni fogod a sok látogatót, mert Tárhelyeink egyedi virtual szerverek és ezt szereti a Google.
-
Honlapszerkesztő tárhelyhez
5 perc alatt lesz honlapod & kockázat nélkül...mobilbarát, gyors és gyönyörű
-
Több honlap egy tárhelyen
Spórolj a minőségi szolgáltatással. Vásárolj osztott tárhelyet, így akár több honlapot is futtathatsz, egyedi domain nevekkel.
-
Tárhely kiegészítők
Egészítsd ki meglévő tárhelyedet:VIP, Google speed, E-mail cím, Tárhely bővítés, Adatbázis.
-
Domain Tárhely egyben
Domain tárhely rendelés kényelmesen. Online, papírok és postázás nélkül megrendelhetsz mindent a honlapod induláshoz. Kattints
-
Google Barát Tárhelyek
-
Szoftveres Segítség
-
Hogyan használd a szoftvereket?
Videó bemutató a domain kereső szoftverek használatához. Érdemes megnézned, mert egy jó domain név akár havi 500 új látogatót is hozhat neked.
-
Domain, amire keresnek!
Találj olyan szavakat, amire valódi emberek keresnek. Alkoss belőlük domain nevet és dőlni fognak a vevők! pl.: hasznaltauto.hu, domainflotta.hu
-
Foglalt a domain? Segítünk!
Foglalt a kigondolt domain? Próbáld ki szoftverünk és alkoss belőle összetett szót. Pl.: virag.hu helyett ViragBolt.hu
-
Értékes Domain - Google kulcsszó alapján
Írd be a számodra legfontosabb kulcsszót (amire az emberek keresnek a Google -ban) és a mesterséges intelligencia javasol neked ÉRTÉKES domain neveket
-
LISTA értékes domainekről
Ezek mind olyan domainek, amik értékesebbek a legtöbb domain névnél. Csak megveszed, ráirányítod a honlapodra és máris megszerezted az erejüket.
-
Domain Figyelő
Unod, hogy minden jó domain név foglat? Pedig van rá megoldás, ezért fogod imádni ezt a szolgáltatást!
-
Hogyan használd a szoftvereket?
- Domain LABOR
-
Domain elkapás - Felszabaduló domainek
Ha szeretnél értékes domain neveket, amivel jobbak az esélyeid? Felszabadul egy domain név, amit szeretnél megszerezni? Imádni fogod ezt a szolgáltatást.
-
DOMAIN névből 450e Ft?
Hogyan keress egy domain névvel 450.000 Ft -ot? Megmutatom. Leírtam mindent lépésről-lépésre, hogy Te is utánam csinálhasd. Kattints.
-
Szakértői Blog
Érdekes és hasznos írások, amik nagyszerű ötleteket és megvalósítható tanácsokat adnak. Ha izgat a domain és a web téma, akkor olvass bele.
-
PartnerProgram
Egy valóban működő partnerkapcsolat. Amiben mi is 3.000 új ügyfelet hozhatunk neked, ha van vállalkozásod.
-
Domain elkapás - Felszabaduló domainek
Témakörök:
Találj meg minket a Google+-on
PHP, valamennyire biztonságosabban
Hogyan tegyük biztonságosabbá a php -ban készült weboldalunkat!
A biztonságot befolyásoló tényezőket két csoportra lehetne osztani. Egyrészt függhetnek a szerver beállításaitól, amelyek főleg a rendszergazdát érintik, másrészt függhetnek maguktól a futtatott PHP programoktól, amelyekért már a programozó a felelős. Valamennyire szétválasztható a kettő egymástól, de hiába ír a programozó majdnem tökéletes kódot, ha egyetlen kis hibát kihasználva hozzá lehet férni nem publikus tartalmakhoz is, mert nincs az Apache, illetve a PHP beállításai között korlátozva a fájlok elérhetősége. Ez persze fordítva is igaz, érdemes összhangban tartani a kettőt.
A php.ini
fontosabb opciói, kapcsolói
A php.ini fájlt megtalálod a virtual szerveren a /conf mappában
register_globals = Off
register_globals
,
akkor is elérhetőek ezek a tömbök. Továbbá ez a módszer garantálja,
hogy a változóidat tényleg onnan kaptad, ahonnan várod őket. Ha minden
űrlapnál GET-tel küldöd el a mezőket, akkor a $_POST
tömbben megjelenő változók nagy valószínűséggel valamiféle amatőr támadási próbálkozás jelei, érdemes lehet naplózni. A $_*
tömbök csak a PHP újabb verzióiban érhetőek el, a régebbiekben használhatóak a $_TIPUS = $HTTP_TIPUS_VARS
értékadások a program elején, melyek esetleg az auto_prepend_file
opcióval automatikussá is tehetők. Ha véletlenül egy Off
értékkel "megáldott" szerveren kell futtatni a nem ilyen szemlélettel
írt programokat, akkor sajnos nagyon nagy munka (lenne) átírni őket,
ezért ilyen esetekben nem biztos, hogy megéri.
display_errors = Off
log_errors = On
tail -f logfile
paranccsal lehet valós időben figyelni. Segítségével olyan hibaüzenetek
is felfedezhetünk, amit esetleg a böngésző elrejtett volna előlünk,
vagy a html forrásban véletlenül például a <!-- -->
tagek közé került volna.
magic_quotes_gpc = Off
addslashes()
függvény használata nélkül SQL függvényekhez történő hozzáférés
biztonságosságán javít, magyarul a vezérlő karakterek elé rak egy \
jelet, ezzel megvédi az adatbázist az SQL parancsba valamiféle módon
bekerülő kártékony kódoktól, amit az adatbázis szerver valószínűleg
parancsként értelmezne. Rontja a teljesítményt, növeli a programozói
hanyagságot, és nem minden adatbázisszerverrel működik együtt. Ráadásul
gondot okoz akkor, ha nem rögtön adatbázisba tesszük az adatokat, hanem
újra megjelenítjük mondjuk egy űrlapban. Ezért javasolt az adatbázisnak
megfelelő escape megoldás használata: pg_escape_string()
, mysql_escape_string()
, sqlite_escape_string()
, stb.
error_reporting = E_ALL
safe_mode = On
safe_mode_gid = Off
safe_mode
csak azokat
az állományokat engedi megnyitni, amelyek felhasználó azonosítója
megegyezik a PHP szkript UID-jével. Ha ezt is bekapcsolod, akkor a
csoport azonosítót is ellenőrzi.
open_basedir = /var/www/
/
fontos, mert ezt hasonlítja
össze az értelmező az állomány abszolút nevével, és ha egyezik az
eleje, akkor engedélyezi a megnyitást. A /var/www
esetén ha létezik például egy /var/www2
könyvtár, akkor az is megnyitható.
disable_functions =
phpinfo()
, az exec()
, a mail()
, stb. függvényekre érdemes használni.
max_execution_time = 30
allow_url_fopen = Off
error_log = syslog
ErrorLog
-ba (ez Apache opció) mennek a hibaüzenetek.
enable_dl = Off
file_uploads = Off
Off
, ha mégis akkor a php_admin_flag
-gel engedélyezzük ott, ahol kell.
upload_tmp_dir =
open_basedir
be van állítva, akkor azon belül kell lennie, különben az állományt annak feltöltése után nem fogjuk tudni kezelni.
A hibaüzenetekről
Tesztelésnél, a program írásánál nagyon hasznosak, de csak a programozó számára, másokkal nem érdemes ezeket megosztani. A felhasználó felől érkező változóknál tapasztalt hibákat csak naplózni érdemes, a hiba okát, az adat ellenőrzésének részleteit lehetőleg ne küldjük ki a böngészőnek, syslog vagy egyéb naplóba írjuk. Ha a jelek mindenképpen arra utalnak, hogy valaki megpróbálja feltörni a programunkat, akkor küldjük át a klienst a főlapra, vagy egyéb módon szórakoztassuk a betörőt.
Kezdőérték nélküli változók
Ezek ellen tökéletes védelmet nyújt a
register_globals
opció kikapcsolása. Bekapcsolt állapotában az alábbi szkriptet elég
könnyű lenne kijátszani, csupán csak a böngészőbe kellene beírni egy http://servercime/akarmi.php?auth=1
URL-t, és a jelszó ismerete nélkül hozzáférhetnénk a bizalmas adatokhoz. Ehhez persze szükséges az $auth
változó nevének az ismerete, amit egy bekapcsolva hagyott display_errors
opció vagy egy biztonsági mentés segítségével a támadó megtudhat. - <?php
- if ($pass == "hello") {
- $auth = TRUE;
- }
- ...
- if ($auth) {
- echo "szupertitkos információk";
- }
- ?>
$auth
változó kezdeti hamis értékének beállításával, illetve az első if
feltételnél egy else
ágban is pótolható a hiányosság.
Beérkező adatok ellenőrzése
Általános szabály az, hogy ne bízzunk meg egyetlen olyan adatban sem, ami a felhasználótól érkezik. A
hidden
típusú űrlap mezőn keresztül érkező adatokat se nehezebb variálni, mint
a többit. A Javascript-es ellenőrzést csak a gyorsasága miatt érdemes
használni, nem helyettesíti a PHP-n belüli ellenőrzéseket. Naplózzuk az
olyan eseteket, amikor a beérkező változók nem normális, a programok
megbuherálása nélkül előidézhetetlen kombinációjával találkozik a
szkriptünk. Ha túl sokszor fordul elő a naplóban, akkor lehet, hogy
mégis mi hibáztunk, és nem számtalan betörési kísérlettel van dolgunk. is_* függvények
Arra valóak, hogy megmondják egy változó típusát. A böngészőtől érkező változók mindig 'string' típusúak, hiszen itt nem végez a PHP automatikus típusválasztást. Azis_numeric()
-el lehet ellenőrizni, hogy egy karaktersorozat valóban számot tartalmaz-e. A PHP a változók típusait automatikusan konvertálja, ha típuskonverzió nélkül kell összehasonlítanod két változót, akkor az
===
és társai nagy segítséget jelentenek, nem mindegy, hogy például egy SQL lekérdezés eredménye hibával tér vissza (FALSE
), vagy nulla (0
) rekorddal. Ha az ==
-vel hasonlítod össze a lekérdezés eredményét tartalmazó változót, mindkét esetben ugyanazt fogod kapni. htmlspecialchars()
Ha a felhasználótól érkező adatokat HTML kimenetbe ágyazva küldöd ki később a böngészőnek (pl. vendégkönyv, fórum), akkor elengedhetetlen a fenti függvény használata. Alkalmazása megvédi attól a weblapot, hogy a felhasználók HTML elemeket illesszenek be az adatok közé, melyek biztonsági kockázatok garmadáját nyitják meg.Adatbázisfüggő escape megoldás
Ha az információk adatbázisban is tárolásra kerülnek, akkor erre is szükség lesz, különben akár egy véletlenül a szövegbe rakott aposztróf vagy idézőjel érvénytelenné teheti az SQL parancsot, illetve kárt is okozhat. Lásd fent..inc fájlok PHP-ben
A konfigurációs, illletve a függvényeket, inicializációs folyamatokat tartalmazó állományokat általában nem ajánlatos önmagában futtatni, ezért egy, a következőhöz hasonló ellenőrzéssel érdemes elküldeni a próbálkozó adatait a syslogba, vagy egyéb naplóállományba:- <?
- // Közvetlenül ezt az állományt kérte a kliens
- if (__FILE__ == $_SERVER["DOCUMENT_ROOT"] . $_SERVER["PHP_SELF"]) {
- // Naplózó kód kerül ide és kilépünk
- die();
- }
- ?>
Amikor nincs szükség a PHP-re
Előfordulhatnak olyan esetek is, amikor a weblap olyan információkat (is) tartalmaz, amelyek ugyan dinamikusan változnak, de csak bizonyos időközönként. A pillanatnyi értékük meghatározott időintervallumonként mindig állandó (pl. az előző napi látogatók száma). Ilyenkor felesleges mindig végrehajtani a bonyolultabbnál bonyolultabb SQL lekérdezéseket, illetve egyéb programrészeket.
A
crontab
-ból periodikusan meghívott wget
,
ami fájlba menti az adott pillanatra jellemző PHP kimenetet, ideálisabb
megoldás az ilyen esetekre, mint a lap minden lehívásakor legenerálni
ugyanazt a végeredményt, és a processzort is kevésbé terheli.
Amennyiben a weblap csak egyes részei tartalmaznak ilyen, bizonyos
ideig állandó információkat, akkor az include()
illetve a require()
függvényekkel érdemes beszúrni a wget
-tel lementett fájlt a megfelelő helyre.Ezek a programok ne legyenek mindenki számára elérhetőek, mert akkor még véletlenül is kitalálhatja valaki az állomány nevét, és így szkriptünk kívülről jövő változókkal is futtathatóvá válik. Ha a gépen shellel rendelkező felhasználók is vannak, akkor csak localhost-ra korlátozni a szkript elérhetőségét sem jó megoldás, inkább a jelszavas elérés használatát javasolnám
.htpasswd
állományok alkalmazásával, amelyekre persze nem adunk mindenkinek olvasási jogot.$HTTP_REFERER ellenőrzés
Ez a változó tartalmazza annak a (űr)lapnak a címét, ahonnan a látogató ide került. A böngésző állítja be, de nem minden esetben. Mivel ez is a felhasználótól jön, nem érdemes nagyon megbízni benne, még akár egy egyszerű telnet klienssel, vagy valamilyen nyílt forrású böngésző átírásával is könnyen lehet hamisítani. Ettől függetlenül érdemes lehet egy plusz védelmi vonalként használni, megvizsgálni, hogy az űrlapokon keresztül beérkező adatok tényleg a mi űrlapunk kitöltésével kerültek-e hozzánk.$HTTP_POST_FILES illetve $_FILES
Az A Study In Scarlet - Exploiting Common Vulnerabilities in PHP című alapműben van egy elgondolkodtató példa a fájl feltöltés kihasználásáról, miszerint afile
típusú beviteli mező által beállított globális változókat ($name
, $name_size
, $name_type
, $name_name
) akár GET metódussal is megadhatjuk a PHP-nek. A beviteli mező name
tulajdonságának megfelelő változó tartalmazza a helyi fájl nevét, ahova
a PHP ideiglenesen elmentette a feltöltött állományt. Ezt GET-tel
beállítva mondjuk a /etc/passwd
-re nagy valószínűséggel ezt a fájlt fogja olvasni a program. Az open_basedir
helyes beállításával, illetve az is_uploaded_file()
függvénnyel kiszűrhetőek az ilyen próbálkozások, de a legjobban itt is a registered_globals
opció alapértelmezett bekapcsolt állapotának megváltoztatásával járunk.
Ajánlom mindenkinek a fenti tömbök használatát, illetve a http://hu.php.net/manual/en/features.file-upload.php címen található leírást.
Biztonsági mentések
Ha a szkripteket shellből is szerkeszted, akkor ügyelj a használt szerkesztők biztonsági mentéseire. Az
akarmi.php
szerkesztés előtti változatát könnyen elérheti bárki kívülről az akarmi.php.bak
vagy akarmi.php~
néven (joe
).
Az nem megoldás, hogy a mentésekben használt kiterjesztésekre is
engedélyezzük a PHP futtatását, mivel elképzelhető, hogy épp egy súlyos
hibát javítottunk, de ott a régi, még hibás szkript is mindenki számára
elérhetően. Ki kell kapcsolni a használt szerkesztők biztonsági mentési
szolgálatását, vagy ezeket a kiterjesztéseket is elérhetetlenné kell
tenni az Apache beállításával.
Sütik
Érzékeny adatok tárolására nem érdemes használni, egy webáruház esetén a vevők nagy mértékű kedvezményekben részesíthetik magukat, ha az árakat is a sütik tartalmazzák. Érdemesebb egy egyedi azonosítót generálni az időből és még valamilyen véletlen információból (IP cím, stb), majd megspékelni valamilyen hash függvénnyel, és mindezt egy SQL táblában tárolni, elsődleges kulcsként használva az így kapott azonosítót. A tábla többi attribútuma pedig logikusan a tárolandó adat legyen. Ha ez dinamikusan változik, akkor egy
text
típusú mezőbe (Postgresql esetén) elég sokmindent bele lehet zsúfolni egy tömb és a serialize()
, illetve unserialize()
függvény segítségével. Itt sem szabad elfelejteni a pg_escape_string()
függvényt és testvéreit más adatbázisok esetén.
Ha találtál valami hasznosat a cikkben, nyomj egy tetszik gombot:
Kérlek írj egy köszönömöt, ha tetszett!
Mi ez, hova kerültem?
A domainflotta.hu honlap tudásbázisát nézed éppen. Rengeteg leírást és szoftveres segítséget adunk, amivel megnövelheted a forgalmad. Vagy épp megvalósíthatod az ötleted.- Mobil barát honlap - 5 perc alatt - hagyd abba a halogatást. Vágj bele
- Tárhely, ami Google barát - előny egy kiélezett versenyben
- Domain regisztráció - biztonságban, értékes ötletekhez
Ezeket már olvastad?
Ehhez elõször kicsit vissza kell ugranunk az idõben 2005-be, amikor is a&nbs...
Megnézte: 67065 ember
Ez az információ már elavult. A Google megszüntette a Gmail összek&ou...
Megnézte: 34222 ember
E-mail fejlécek megjelenítése - felhasználói segédlet - Tartalomjegyzék E-mail fejl...
Megnézte: 34147 ember
A leggyakoribb eset Az új domain szabályzat szerint 4 munkanap alatt elbírálják a doma...
Megnézte: 31492 ember
Ez a "hibaüzenetet" a böngészõd írja ki, amikor megpróbálsz belépni a webes leve...
Megnézte: 29666 ember
Sokan nem tudják, pedig létfontosságú:A Google bünteti a duplikált tartalmakat. Így a...
Megnézte: 25451 ember
A rendelés díjának befizetésérõl:A rendelésed rögzítésekor küldünk e-mailben egy prof...
Megnézte: 25414 ember
Böngészõ segítségével Hogyan? A következõ webcímre látogass el e...
Megnézte: 24637 ember
Domain nevet csak ip címre vagy dns címekre lehet irányítani. Az ip cím formátuma: 127.0.0....
Megnézte: 24636 ember
Mire jó?Nagyon sok olyan eset van, amikor be kell illeszteni egy html kódot az oldalba. Ez...
Megnézte: 21292 ember