Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [php] Bezpieczne includowanie plików
mos
post
Post #1





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 10.01.2011
Skąd: kierunek-->Południe

Ostrzeżenie: (0%)
-----


Od zawsze zastanawiała mnie sprawa - na ile to możliwe - bezpiecznego includowania/wyświetlania includowanych plików. Czy takie rozwiązanie wydaje się Wam bezpiecznym:
  1. $dostepne_strony = array('info','szukaj');
  2. if(isset($_GET['pokaz'])) {
  3. $pokaz = $_GET['pokaz'];
  4. } else {
  5. $pokaz='';
  6. }
  7. if(!in_array($pokaz,$dostepne_strony)) $pokaz=$dostepne_strony[0];
  8. if(file_exists($pokaz.'.php')) include($pokaz.'.php');
  9. else echo '<p>brak strony do wyświetlenia</p>';
  10. ?>

no właśnie - jak bezpiecznie includować pliki? Trzeba/należy używać DEFINE, czy może ten sposób wystarczy?
Zapraszam do dyskusji.

Ten post edytował mos 17.06.2011, 08:59:13
Go to the top of the page
+Quote Post
glencun
post
Post #2





Grupa: Zarejestrowani
Postów: 38
Pomógł: 0
Dołączył: 15.06.2011

Ostrzeżenie: (0%)
-----


Jest to bezpieczne, bo sprawdzasz czy dany plik istnieje, nie mniej jednak przydałoby się jeszcze oczyścić wprowadzone dane z $_GET, koniecznie.

Z kolei jeśli chodzi o tablicę z nazwami, to musiałbyś ją aktualizować cały czas albo skorzystać z glob.
Go to the top of the page
+Quote Post
mos
post
Post #3





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 10.01.2011
Skąd: kierunek-->Południe

Ostrzeżenie: (0%)
-----


żebyśmy mieli jasność - akurat (jak dla mnie) nie trzeba tłumaczyć co znaczy kod, ale dzięki za dokładność - może przyda się innym! ;-)
natomiast chciałbym wiedzieć czy można zastosować tu jakiś hak etc. :-)
co do tablicy nazw - to owszem, faktycznie. Można tutaj zastosować jakieś zmiany - zmienne nadawane z np. panelu administracyjnego
Go to the top of the page
+Quote Post
toaspzoo
post
Post #4





Grupa: Zarejestrowani
Postów: 778
Pomógł: 84
Dołączył: 29.07.2010
Skąd: Gliwice / Pławniowice Mistrz niezmordowanej klawiatury.

Ostrzeżenie: (20%)
X----


includowane pliki znajdują się na serwerze, więc ty masz nad nimi kontrolę.

Domyśle nie można includować plików z innych serwerów, z powodów bezpieczeństwa

allow_url_fopen

http://www.php.net/manual/en/filesystem.co...allow-url-fopen

Reszta bezpieczeństwa zależy od skryptu - im prostszy, tym mniejsza szansa (IMG:style_emoticons/default/wink.gif)
Go to the top of the page
+Quote Post
nekomata
post
Post #5





Grupa: Zarejestrowani
Postów: 314
Pomógł: 44
Dołączył: 12.11.2010
Skąd: UK

Ostrzeżenie: (0%)
-----


@up myślę że nawet jak wykręcisz skrypt formatu chińskiej armii to jak dokładnie przefiltrujesz dane jesteś bezpieczny , tylko za każdym razem sprawdzaj czy to co otrzymujesz od użytkownika jest tym co chcesz (preg_match , is_num itd) osobiście ja używam głównie preg match'a bo wszystko można sobie w regex'ie 'wybrać' łatwiutko .
Go to the top of the page
+Quote Post
mos
post
Post #6





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 10.01.2011
Skąd: kierunek-->Południe

Ostrzeżenie: (0%)
-----


ano tak powinno być, natomiast z racji, że przesyłane jest to - w tym przypadku - GET'em, zastanawiam się, czy nie ma jakiegoś sposobu na zatrucie tego kodu, np przez zatrucie URL'a. Jest niby tablica w której dozwolone strony są sprawdzane, ale mimo to, chciałem zapytać Was o zdanie :-)
Go to the top of the page
+Quote Post
toaspzoo
post
Post #7





Grupa: Zarejestrowani
Postów: 778
Pomógł: 84
Dołączył: 29.07.2010
Skąd: Gliwice / Pławniowice Mistrz niezmordowanej klawiatury.

Ostrzeżenie: (20%)
X----


@up

Jest sposób "na zatrucie" wszystkiego, nawet silnika php na serwerze
Go to the top of the page
+Quote Post
mos
post
Post #8





Grupa: Zarejestrowani
Postów: 17
Pomógł: 0
Dołączył: 10.01.2011
Skąd: kierunek-->Południe

Ostrzeżenie: (0%)
-----


nie chodzi mi tu o ekstrema. Byłem ciekaw czy coś przeoczyłem.
Tak na marginesie najistotniejsze są dla mnie - a i sądzę że dla kogoś kto zainteresuje się tym tematem - konstruktywne odpowiedzi - co zrobić, żeby było jak ma być + np. funkcja która może temu pomóc ;-)
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 25.08.2025 - 02:51