Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP][MYSQL] zmienna GET a zapytanie do bazy mysql
Forum PHP.pl > Forum > Przedszkole
!*!
tak dla sprawdzenia jak to działa robię wyszukiwarkę, po wpisaniu do inputa przesyłam to getem do bazy, ale mam kilka pytań związanych z takimi zapytaniami.

  1. <?php
  2. //pobranie szukanego słowa ze zmiennej wysłanej inputem
  3.  
  4. $wynik = ucp(wds($_GET['wyszukaj']));
  5.  
  6. // dalej zapytanie do mysql odwołujące się do zmiennej $wynik
  7. ?>


fukncja ucp:

  1. <?php
  2. function ucp($zrodlo){
  3. $zrodlo = preg_replace("//",'',$zrodlo);
  4. $zrodlo = preg_replace("/\"/",'',$zrodlo);
  5. $zrodlo = preg_replace("/'/",'',$zrodlo);
  6. $zrodlo = preg_replace("/</",'',$zrodlo);
  7. $zrodlo = preg_replace("/>/",'',$zrodlo);
  8. $zrodlo = preg_replace("/=/",'',$zrodlo);
  9. $zrodlo = preg_replace("/%/",'',$zrodlo);
  10. $zrodlo = preg_replace("/--/",'',$zrodlo);
  11. $zrodlo = strtolower($zrodlo);
  12. $zrodlo = trim($zrodlo);
  13. return $zrodlo;
  14. }
  15. ?>


funkcja wds:

  1. <?php
  2. function wds($zrodlo){return htmlspecialchars(mysql_real_escape_string(trim($zrodlo)));}
  3. ?>


Może tak być, aby zapytanie do bazy było prawidłowe? Bez żadnych niespodzianek z wysłaniem spreprawowanego kodu

Idąc dalej chciałbym wyświetlić ten wyraz który podałem w inpucie jako echo, czyli

  1. <?php
  2. echo $wynik;
  3. ?>


ale tu mam zgryz bo, jeśli wpiszę taki wyraz:

Kod
coś"tam"\/\\\/'zczcx'


w adresie strony jest:

Kod
co%C5%9B%22ta%22%5C%2


to powinny zostać usuniętę wszytkie znaki, \ " i ' ale nie ma tak dobrze i zostaje sam cudzysłów, pomimo że fukncja powinna go usunąć...

Jak zbudować odpowiednie filtrny aby wyraz był wysyłany bezpiecznie do bazy a wywietlany czysty bez znaków " i ' ?

przy próbie odczu w takiej formie:

  1. <?php
  2. function ozs($zrodlo){return stripslashes(trim($zrodlo));}
  3.  
  4. echo ozs($wynik);
  5. ?>


Nadal nie ma czystego wyrazu...
wookieb
Wystarzczy SAMO http://php.net/mysql_real_escape_string
sowiq
A na przyszłość do zamiany/wyrzucenia pojedynczego znaku ze stringa używaj str_replace()
!*!
Kod
function ucp($zrodlo){
$zakaz = array("\\","\"","<",">","'","%","=");
$zrodlo = str_replace($zakaz, "", $zrodlo);
$zrodlo = trim($zrodlo);
return $zrodlo;
}


I tak ma być jak chce usunąć sam \ to wpisuje \\? a nie jak w przypadku /\\\/ ? Poza tym dlaczego wymagany jest przy tym / a przy innych znakach już nie?

Poza tym nadal nie wiem dlaczego nie usuwa znaku cudzysłowia oraz < > ze stringu który chce wyświetlić
Pilsener
1. mysql_real_escape_string - zabezpieczy przed sql injection
2. urlencode - zakoduje znaki specjalne w adresie

Ja nie lubię przekazywać w adresie takich rzeczy - najczęściej wrzucam kryteria do bazy (bo i tak robię staty, co, kto i keidy szuka etc.), a w adresie wystarczy dać: kryteria=1234 - nowe szukanie to nowe id.
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.