Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [ZF] czy przy updacie mam w jakis sposob zabezpieczac dane czy nie ?
Forum PHP.pl > Forum > PHP > Frameworki
wiewiorek
jak robie update:
  1. public function updateStrona($id_strony, $tytul, $tresc)
  2. {
  3. $data = array(
  4. 'tytul' => $tytul,
  5. 'tresc' => $tresc,
  6. );
  7.  
  8. $this->update($data, 'id = '. (int)$id_strony);
  9. }


a dane w parametrach $id_strony, $tytul, $tresc pochodzą od użytkownika to mam je zabezpieczać przed atakami SQL injection czy nie ? Czy jest w takiej sytuacji automatyczna ochrona czy nie ?
zend
  1. $where['reported_by = ?'] = 'goofy';
  2. $where['bug_status = ?'] = 'OPEN';
  3. $n = $db->update('bugs', $data, $where);
korzystaj z takiego zapisu, zend zadba o bezpieczeństwo danych

update
wiewiorek
Ale mi nie chodzi o $where - to akurat wiadomo, że jest zabezpieczane przez zenda, bo widze '?' - znak zapytania - czyli parametryzacja zapytań. Chodzi mi o zmienną $data, a właściwie dane w tej tablicy. Co z nimi ?
zend
ZF zajmie się zabezpieczeniem ich, nie musisz się o to przejmować
wiewiorek
dzieki smile.gif
Pilsener
Jeśli mogę coś dodać: po co Ci metoda, która tak naprawdę nic nie robi poza pośrednictwem (przekazuje zmienne z kontrolera do db_table)? Zamiast:
  1. $model->updateStrona($co,$gdzie);


Nie prościej:
  1. $model->update($co,$gdzie);
-?

O zabezpieczenie sql injection nie musisz się martwić, ale nie zwalnia Ciebie to z obowiązku filtrowania parametrów i danych wrzucanych do bazy (np. kodu HTML).
zend
No tak, może, ale może oprócz tego kodu który nam pokazał ma jakąś inną logikę np usuwanie cache'u i trzyma ją w modelu, a nie chce nadpisywać metody update
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.