Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP]fopen z get'a a bezpieczeństwo
dk1342
post 21.03.2009, 12:18:40
Post #1





Grupa: Zarejestrowani
Postów: 275
Pomógł: 9
Dołączył: 24.07.2008
Skąd: Racibórz

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


Witam, otóż zrobilem sobie licznik pobrań do mojego uploadu na plikach tekstowych, wszystko ładnie działa ale teraz wyświetlanie ilości pobrań a bezpieczeństwo mam tak:

  1. <?php
  2. $f = fopen('files/dane/'.$id.'.txt', 'r');
  3. $pobrano = fread($f, filesize('files/dane/'.$id.'.txt'));
  4. echo "<tr><td>Pobrano: </td><td>".$pobrano."</td></tr>";
  5. fclose($f);
  6. ?>


ok to działa ale wydaje mi się że to nie jest bezpieczne ponieważ zmienna $id = $_GET['id'];
czyli w linku podaje nazwe pliku plik.php?id=cos.jpg
I teraz moje pytanie czy jest to bezpieczne a jak nie to jak to moge zabezpieczyć ?

Ten post edytował dk1342 21.03.2009, 12:19:24


--------------------
Firefox - The Best,
Internet Exokier - shit

Go to the top of the page
+Quote Post
erix
post 21.03.2009, 12:20:54
Post #2





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




basename" title="Zobacz w manualu PHP" target="_manual


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
dk1342
post 21.03.2009, 12:24:29
Post #3





Grupa: Zarejestrowani
Postów: 275
Pomógł: 9
Dołączył: 24.07.2008
Skąd: Racibórz

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


po oglądałem trochę ale zabardzo nie wiem jak to wykorzystać hm:

  1. <?php
  2. $id = $_GET['id'];
  3. $plik = basename('files/dane/'.$id.'.txt');
  4. $f = fopen($plik, 'r');
  5. ?>


tak ?

Ten post edytował dk1342 21.03.2009, 12:25:34


--------------------
Firefox - The Best,
Internet Exokier - shit

Go to the top of the page
+Quote Post
Spawnm
post 21.03.2009, 12:26:55
Post #4





Grupa: Moderatorzy
Postów: 4 069
Pomógł: 497
Dołączył: 11.05.2007
Skąd: Warszawa




zobacz 1 przykład:
  1. <?php
  2. $sciezka = "/home/httpd/html/index.php";
  3. $plik = basename($sciezka);         // $plik jest ustawiony na "index.php"
  4. $plik = basename($sciezka, ".php"); // $plik jest ustawiony na "index"
  5. ?>


a na forum było już dużo o zabezpieczaniu , poszukaj ...
Go to the top of the page
+Quote Post
dk1342
post 21.03.2009, 12:28:54
Post #5





Grupa: Zarejestrowani
Postów: 275
Pomógł: 9
Dołączył: 24.07.2008
Skąd: Racibórz

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


  1. <?php
  2. $sciezka = "/files/dane/".$id;
  3. $plik = basename($sciezka, ".txt");
  4. $f = fopen($plik, 'r');
  5. ?>


tak ?

Ten post edytował dk1342 21.03.2009, 12:29:10


--------------------
Firefox - The Best,
Internet Exokier - shit

Go to the top of the page
+Quote Post
erix
post 21.03.2009, 12:42:56
Post #6





Grupa: Moderatorzy
Postów: 15 467
Pomógł: 1451
Dołączył: 25.04.2005
Skąd: Szczebrzeszyn/Rzeszów




A nie możesz spróbować? Nie pytaj nas, tylko próbuj; oszczędzisz czas swój i nasz.


--------------------

ZCE :: Pisząc PW załączaj LINK DO TEMATU i TYLKO w sprawach moderacji :: jakiś błąd - a TREŚĆ BŁĘDU? :: nie ponaglaj z odpowiedzią via PW!
Go to the top of the page
+Quote Post
dk1342
post 21.03.2009, 12:56:43
Post #7





Grupa: Zarejestrowani
Postów: 275
Pomógł: 9
Dołączył: 24.07.2008
Skąd: Racibórz

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


ok to mam tak:

  1. <?php
  2. $id = $_GET['id'];
  3. $sciezka = "files/dane/".$id.".txt";
  4. $plik = basename($sciezka);
  5. $f = fopen("files/dane/".$plik, 'r');
  6. $pobrano = fread($f, filesize('files/dane/'.$plik));
  7. echo "<tr><td>Pobrano: </td><td>".$pobrano."</td></tr>";
  8. fclose($f);
  9. ?>


śmiga ale dobrze to zrobiłem ? jest zabezpieczone ? bo nie wiem, nie jestem hackerem


--------------------
Firefox - The Best,
Internet Exokier - shit

Go to the top of the page
+Quote Post

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

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 07:47