Portál AbcLinuxu, 5. května 2024 13:05


Dotaz: PHP - zabezpečení přístupu neznámé aplikace

6.2.2014 01:29 xts | skóre: 10
PHP - zabezpečení přístupu neznámé aplikace
Přečteno: 293×
Odpovědět | Admin
Zdravím,

dostal jsem se na následující problém:

firma má nějakou jednoduchou db aplikaci psanou v php, na nějaký rozpočty, odpracovaný hodiny atd. Jelo to lokálně takže nikdo nějak moc neřešil zabezpečení, co jsem se matně díval do kódu tak jenom úplně základní. Nyní ovšem nastala situace kdy by k aplikaci chtěli přistupovat i vzdáleně když nebudou v kanceláři. Použití v mobilech/tabletech prakticky vylučuje vpn a podobný věci který se pro usera složitě nastavujou a není zaručená funkčnost, takže se jedná o klasický přístup přes https.

Tu aplikaci moc neznám, nevím jak bezpečný tam kdo má hesla (myslím že minimálně), nemám čas to celý procházet (a ani nejsem takovej odborník na zabezpečení abych ošetřil všechno) a vypadá to že časem se to přepíše úplně nově takže by ani moc nemělo smysl do toho ten čas a peníze investovat. Nicméně potřebuju to zabezpečit proti skript kiddies, botům apod. Neřeší se nabourání ze strany oprávněných osob (zaměstnanců) - tam má přístup každej všude, potřebuju aby ta aplikace nebyla vystavená hned celýmu světu.

A teď mě napadlo: co když udělám jednoduchej php skript třeba auth.php, kde bude formulář na zadání kvalitního hesla (nebo jméno+heslo, to je jedno), vstup hesla bude ošetřenej třeba na znaky a-z0-9, a pokud se heslo ověří tak to zapíše ip do texťáku (nebo db) a tu ip to třeba na hodinu, den apod. povolí. Pak do všech .php souborů tý aplikace dám na začátek jednoduchou podmínku pokud ip neni v texťáku tak přesměrovat na auth.php bez pokračování skriptu - takže tohle tu ip jakoby odemkne pro přístup. Případně ještě zkombinovat s cookies a/nebo session. Případně by tohle šlo dát i do index.php.

Co si o tom myslíte, nebo napadá vás lepší řešení? Bude to +- bezpečný?

Neřeším podvrhnutou ip, a server jako takovej předpokládám zabezpečenej, php 5.3.6.

díky za nápady

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Řešení 1× (xts (tazatel))
AraxoN avatar 6.2.2014 02:13 AraxoN | skóre: 47 | blog: slon_v_porcelane | Košice
Rozbalit Rozbalit vše Re: PHP - zabezpečení přístupu neznámé aplikace
Odpovědět | | Sbalit | Link | Blokovat | Admin
Tak ako si to napísal by sa to malo dať urobiť. Ale keď už tam musia zadávať heslo, tak ho rovno môžu zadať v HTTP autentifikácii a netreba ani robiť ďalšiu stránku a prerábať skripty. Stačí nastaviť v Apache:
<Directory "/var/www/whatever">
	AuthType Basic
	AuthName "Zadaj heslo"
	AuthUserFile /var/www/whatever/.htpasswd
	Require valid-user

	Order allow,deny
	Allow from 192.168.0.0/24
	Allow from 12.34.56.78
	Allow from 127.0.0.1
	Satisfy any
</Directory>
6.2.2014 11:20 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: PHP - zabezpečení přístupu neznámé aplikace
jj, tohle je asi nejjednodušší cesta + https, je to rychlé a odolné
6.2.2014 15:46 xts | skóre: 10
Rozbalit Rozbalit vše Re: PHP - zabezpečení přístupu neznámé aplikace
diky - tohle by melo fungovat bez problemu i na tabletech/telefonech a vypada to jednodussi. To satisfy any je genialni, ani jsem netusil ze apache neco takovyho umi.. diky vsem
6.2.2014 15:55 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
Rozbalit Rozbalit vše Re: PHP - zabezpečení přístupu neznámé aplikace
Jen nezapomeň na https.
To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
6.2.2014 11:28 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
Rozbalit Rozbalit vše Re: PHP - zabezpečení přístupu neznámé aplikace
Odpovědět | | Sbalit | Link | Blokovat | Admin
a pokud to chcete řešit php login/passwd, nic nebrání použití cookies, a pokud neni cookie nastaveno, šup na formulář login/passwd. Ale je to větší drbačka než přes .htaccess nastavit hesla

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.