Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [MySQL][PHP]Ocena sensu funkcji filtrującej tekst przed dodaniem
Forum PHP.pl > Forum > Przedszkole
MalyKazio
Witam,

Poprawiam, stary, odkopany gdzieś skrypt i dotarłem do funkcji, która ma przetwarzać tekst przed dodaniem go do bazy MySQL. W związku z tym moje pytanie. Czy takie cudo ma sens:
  1. function przygotujinputtekst($wartosc) {
  2. $wartosc = trim($wartosc);
  3. $wartosc = html_entity_decode($wartosc, ENT_QUOTES, 'UTF-8');
  4. $wartosc = strip_tags($wartosc);
  5. $wartosc = mysql_real_escape_string($wartosc);
  6. } else {
  7. $wartosc = stripslashes($wartosc);
  8. $wartosc = mysql_real_escape_string($wartosc);
  9. }
  10. return $wartosc;
  11. }
lobopol
Nie wiem czy jest sens używania tych 2 linijek:
  1. $wartosc = html_entity_decode($wartosc, ENT_QUOTES, 'UTF-8');
  2. $wartosc = strip_tags($wartosc);

i możesz sobie odrobinę skrócić kod
  1. $wartosc = stripslashes($wartosc);
  2. }
  3. $wartosc = mysql_real_escape_string($wartosc);

MalyKazio
Chyba ma sens, bo czasem dane tekstowe wyświetlane są w formularzu do edycji. Przed ich wyswietleniem przechodzą przez funkcję htmlentities()
Za manualem:
  1. <?php
  2. $str = "A 'quote' is <b>bold</b>";
  3.  
  4. // Outputs: A 'quote' is &lt;b&gt;bold&lt;/b&gt;
  5.  
  6. // Outputs: A 'quote' is &lt;b&gt;bold&lt;/b&gt;
  7. echo htmlentities($str, ENT_QUOTES);
  8. ?>

Bez
  1. $wartosc = html_entity_decode($wartosc, ENT_QUOTES, 'UTF-8');

Część znaków z // Outputs: A 'quote' is &lt;b&gt;bold&lt;/b&gt;
zostałaby ponownie przetworzona przez mysql_real_escape_string();, czyż nie?
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.