Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Zapezbieczanie się przed XSS oraz innego typu...
AndyPSV
post 6.08.2004, 14:20:37
Post #1





Grupa: Zarejestrowani
Postów: 393
Pomógł: 5
Dołączył: 6.02.2003
Skąd: The.Luciferian.Doctrine.p
df

Ostrzeżenie: (30%)
XX---


Da się całkowicie zabezpieczyć przed atakami XSS oraz SQL injection, filtrująć każdą zmienną GET i POST.

Przykładowo:

  1. <?php
  2.  
  3. foreach ($_GET as $value) {
  4. if ((eregi(&#092;"<[^>]*script*\"?[^>]*>\", $value)) ||
  5. (eregi(&#092;"<[^>]*object*\"?[^>]*>\", $value)) ||
  6. (eregi(&#092;"<[^>]*iframe*\"?[^>]*>\", $value)) ||
  7. (eregi(&#092;"<[^>]*applet*\"?[^>]*>\", $value)) ||
  8. (eregi(&#092;"<[^>]*meta*\"?[^>]*>\", $value)) ||
  9. (eregi(&#092;"<[^>]*style*\"?[^>]*>\", $value)) ||
  10. (eregi(&#092;"<[^>]*form*\"?[^>]*>\", $value)) ||
  11. (eregi(&#092;"([^>]*\"?[^)]*)\", $value)) ||
  12. (eregi(&#092;"\"\", $value)) ||
  13. (eregi(&#092;"'\", $value)) ||
  14. (eregi(&#092;"<[^>]*\", $value)) ||
  15. (eregi(&#092;"[^>]>\", $value)) ||
  16. (eregi(&#092;"*\", $value)) ||
  17. (eregi(&#092;"[]]\", $value)) ||
  18. (eregi(&#092;"select\", $value)) ||
  19. (eregi(&#092;"0x73656c656374\", $value)) ||
  20. (eregi(&#092;";\", $value)) ||
  21. (eregi(&#092;"--\", $value)) ||
  22. (eregi(&#092;"@\", $value)) ||
  23. (eregi(&#092;"/\", $value)) ||
  24. (eregi(&#092;"%\", $value))
  25. )
  26. {
  27. ..
  28. }
  29. }
  30.  
  31. foreach ($_POST as $value) {
  32. if ((eregi(&#092;"<[^>]*script*\"?[^>]*>\", $value)) ||
  33. (eregi(&#092;"<[^>]*style*\"?[^>]*>\", $value)))
  34. {
  35. ..
  36. }
  37. }
  38.  
  39. ?>

.

Jednak owo filtrowanie można ominąć w bardzo prosty sposób.
Podająć wartość $_GET jako: %3Cscript%3Ealert%28document.cookie%29%3B%3C%2Fscript%3E (XSS).

Jednak można jeszcze kilkoma technikami ominąć filtrowanie, stosująć kodowanie.

Problem: Jak się zabezpieczyć do granic możliwości przechodząć przez wszystkie zmienne $_GET i $_POST ?
Go to the top of the page
+Quote Post

Posty w temacie


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 - 12:20