Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [PHP]Zabezpieczenie $_POST i $_GET
patryk9200
post
Post #1





Grupa: Zarejestrowani
Postów: 319
Pomógł: 4
Dołączył: 7.02.2009
Skąd: pless

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


Cześć,
Da może się zrobić tak żeby każdą tablicę w skrypcie bez wyjątku $_GET lub $_POST był "oczyszczony" z wszelakiego kodu PHP i zapytań MySQL ?
Tylko zależy mi na tym żeby $_POST html można było przesyłać...
Jak takie coś zrobić?

Ten post edytował patryk9200 24.07.2009, 19:09:03
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 7)
Pawel_W
post
Post #2





Grupa: Zarejestrowani
Postów: 1 675
Pomógł: 286
Dołączył: 15.06.2009
Skąd: Wieliczka

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


mysql_real_escape_string" title="Zobacz w manualu PHP" target="_manual i strip_tags" title="Zobacz w manualu PHP" target="_manual

mogłem przekręcić nazwy (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)

EDIT: jeżeli chodzi o przesyłanie kodu html to strip_tags odpada, musisz sobie napisać własną funkcję, albo jako drugi parametr funkcji podać wszystkie wyjątki

Ten post edytował Pawel_W 24.07.2009, 19:14:11
Go to the top of the page
+Quote Post
patryk9200
post
Post #3





Grupa: Zarejestrowani
Postów: 319
Pomógł: 4
Dołączył: 7.02.2009
Skąd: pless

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


tylko mi chodzi i to żeby odrazu jak zastosuję gdzieś w kodzie np. $_GET[] to już było oczyszczone wywołując tylko raz odpowiedni skrypt na początku strony...
Go to the top of the page
+Quote Post
Pawel_W
post
Post #4





Grupa: Zarejestrowani
Postów: 1 675
Pomógł: 286
Dołączył: 15.06.2009
Skąd: Wieliczka

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


  1. <?php
  2. foreach($_GET as $klucz => $wartosc)
  3. $_GET[$klucz] = strip_tags($_GET[$klucz])
  4. ?>


tak samo dla $_POST
Go to the top of the page
+Quote Post
erix
post
Post #5





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




array_walk" title="Zobacz w manualu PHP" target="_manual... (IMG:http://forum.php.pl/style_emoticons/default/dry.gif)
Go to the top of the page
+Quote Post
Fifi209
post
Post #6





Grupa: Zarejestrowani
Postów: 4 655
Pomógł: 556
Dołączył: 17.03.2009
Skąd: Katowice

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


Cytat(Pawel_W @ 24.07.2009, 19:10:19 ) *
mysql_real_escape_string" title="Zobacz w manualu PHP" target="_manual i strip_tags" title="Zobacz w manualu PHP" target="_manual

mogłem przekręcić nazwy (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg)

EDIT: jeżeli chodzi o przesyłanie kodu html to strip_tags odpada, musisz sobie napisać własną funkcję, albo jako drugi parametr funkcji podać wszystkie wyjątki


To już chyba prościej włączyć magic_quotes
Go to the top of the page
+Quote Post
erix
post
Post #7





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




Też o tym samym pomyślałem, ale w PHP6 tego nie będzie, AFAIK.
Go to the top of the page
+Quote Post
tomekpl
post
Post #8





Grupa: Zarejestrowani
Postów: 134
Pomógł: 5
Dołączył: 9.08.2008
Skąd: Szczecin

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


  1. <?php
  2. $arrArguments = array();
  3.  
  4.    $intArgumentIndex = 0;
  5.  
  6.    function parseArgument($arrMatches) {
  7.  
  8.        global $arrArguments, $intArgumentIndex;
  9.  
  10.        $strMatch = $arrMatches[0];
  11.  
  12.        $strArgument = @$arrArguments[$intArgumentIndex++];
  13.  
  14.        switch ($strMatch) {
  15.  
  16.            case '%d': return (int)$strArgument;
  17.  
  18.            case '%s': return '"'.
  19.  
  20.              mysql_real_escape_string($strArgument).'"';
  21.  
  22.            case '%b': return (int)((bool)$strArgument);
  23.  
  24.        }    
  25.  
  26.    }
  27.  
  28.    function SQL($strSql) {
  29.  
  30.        global $arrArguments, $intArgumentIndex;
  31.  
  32.        $arrArgs = func_get_args();
  33.  
  34.        array_shift($arrArgs);
  35.  
  36.        $arrArguments = $arrArgs;
  37.  
  38.        $intArgumentIndex = 0;
  39.  
  40.        return preg_replace_callback('/(%[dsb])/', 'parseArgument',
  41.  
  42.          $strSql);    
  43.  
  44.    }
  45. ?>



(IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
A jak masz GET to prawie zawsze przesyłasz tam jakieś wartości liczbowe
$zmienna=intval($_GET['jakasget'])

przepusci tylko liczby
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: 23.08.2025 - 15:55