• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Mysqli - prepare czy real_escape_string

+1 głos
472 wizyt
pytanie zadane 14 października 2020 w PHP przez Akiz521 Początkujący (480 p.)

Cześć czy jest jakaś różnica w bezpieczeństwie między:

1. mysqli: prepare

np. 

$stmt = $mysqli->prepare("SELECT * FROM myTable WHERE name = ? AND age = ?");
$stmt->bind_param("si", $_POST['name'], $_POST['age']);
$stmt->execute();

2. mysqli_real_escape_string

np.

function test($var) {

 $var = mysqli_real_escape_string($system_db_link, stripslashes($var));

 return $var;

}

 

Wtedy w czystym query np.:

'(...) WHERE user='.test($login).'LIMIT 1';

 

 

Co najlepiej używać? Najwygodniejsza byłaby opcja druga, bo można np. zrobić funkcje tak jak wyżej, więc będzie o wiele mniej linijek kodu.

 

1 odpowiedź

+1 głos
odpowiedź 15 października 2020 przez VBService Ekspert (256,580 p.)

Real escape string vs bind param

Tu masz przykład (db_functions.php), że $mysqli->prepare $stmt->bind_param, też można "wrzucić" do funkcji. wink

 

1
komentarz 15 października 2020 przez Akiz521 Początkujący (480 p.)
Dzięki za odpowiedź.

Pisząc o funkcji, miałem na myśli taką gotową/uniwersalną, bo w przypadku real_escape_string to mogę mieć przykładowo funkcję:

dbQuery() no i funkcję tę z mojego pierwszego postu: test(). Wtedy mogę użyć ich np. tak:

$costam = dbQuery('(...) WHERE user='.test($login).'LIMIT 1');
komentarz 15 października 2020 przez VBService Ekspert (256,580 p.)

@Lerion, spoko, podałem Tobie to jako przykład, ale ostateczna decyzja należy do Ciebie, w końcu to Twoje dzieło. wink

komentarz 15 października 2020 przez Akiz521 Początkujący (480 p.)
Rozumiem, może komuś przyjdzie do głowy jakieś rozwiązanie (nie oczekuję gotowca tylko chociaż pomysłu) żeby jakoś ułatwić zapytania do bazy (używając prepare).

Podobne pytania

0 głosów
0 odpowiedzi 154 wizyt
pytanie zadane 18 sierpnia 2020 w PHP przez Paweł Barszcz Użytkownik (950 p.)
0 głosów
1 odpowiedź 450 wizyt
pytanie zadane 6 marca 2020 w PHP przez chin24 Nowicjusz (150 p.)
0 głosów
1 odpowiedź 437 wizyt
pytanie zadane 2 maja 2018 w PHP przez Damian Prymus Początkujący (380 p.)

93,742 zapytań

142,678 odpowiedzi

323,297 komentarzy

63,326 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Twierdza Linux. Bezpieczeństwo dla dociekliwych

Aby uzyskać rabat -10%, użyjcie kodu pasja-linux, wpisując go w specjalne pole w koszyku.

...