Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Blokada adresów email
Forum PHP.pl > Forum > PHP
mith
Witam
Jak można zrobić taki skrypt?:

Mam taką bazę danych:

zablokowane: |
janek_k |
@wp.pl |
@onet.pl |
costam |

I jak jakiś użytkownik poda adres email (np. bo_janek_k@cos.pl lub bleble@wp.pl) gdzie będzie występowała któraś z nazw znajdujących się w bazie danych to wyświetli mu się komunikat np. ten adres jest zablokowany.

Za odpowiedź dzięki z góry
wipo
Kod
$adresy=array('adres1','adres2','adres3');

if (in_array($_POST['adres'],$adresy)) print "adres zablokowany"; else {
//wysyłanie
}

adresow w tablicy mozesz miec więcej
w formularzu musisz mieć pole adres - lub inne ale to zmień powyżej
erix
Wipo, ale co to da? Zablokujesz tylko konkretne adresy, a nie domeny.

preg_replace" title="Zobacz w manualu php" target="_manual
W komentarzach użytkowników jest zamiana maili na hrefy, ale wystarczy lekko zmodyfikować szukane wyrażenie i zamiennik.
wipo
Cytat(erix @ 19.10.2006, 21:09:11 ) *
Wipo, ale co to da? Zablokujesz tylko konkretne adresy, a nie domeny.

preg_replace" title="Zobacz w manualu php" target="_manual
W komentarzach użytkowników jest zamiana maili na hrefy, ale wystarczy lekko zmodyfikować szukane wyrażenie i zamiennik.

ale zamiast adresu mozesz dac domeny i juz albo dac array_search
mith
A jak ja chce to mieć w SQL biggrin.gif a nie w array to jak to zrobić?
wipo
mysql_query("select adres from adresy_zablokowane where adres like '%".$_POST['adres']."%'");
zwróci Ci adresy które są zablokowane i zawierają cokolwiek z wpisanej rzeczy
mith
Cytat
mysql_query("select adres from adresy_zablokowane where adres like '%".$_POST['adres']."%'");
zwróci Ci adresy które są zablokowane i zawierają cokolwiek z wpisanej rzeczy


Tyle to i ja wiem biggrin.gif ale jeśli w $_POST['adres'] będzie podany adres: costam@wp.pl
A w SQL mam byle jaki fragment tego meila np. cos, @wp.pl lub tam@ to i tak mi nawet tego meila nie zablokuje bo użytkownik podaje całego meila a nie fragment a z tego co mi wiadomo to: like '%".$_POST['adres']."%' wpisuje się fragment tego czego szukam.
erix
Cytat
like '%".$_POST['adres']."%'


  1. <?php
  2. $adres = explode('@', $_POST['adres']);
  3.  
  4. mysql_query('select adres from adresy_zablokowane where adres like "%@'.$adres[1].'"');
  5. ?>
jarrod
Cytat(wipo @ 19.10.2006, 21:14:03 ) *
ale zamiast adresu mozesz dac domeny i juz albo dac array_search

Niestetty przy kodzie który napisałeś powyżej ani podanie adresu domeny ani array_search by tu nic nie wskórało...
array_search" title="Zobacz w manualu php" target="_manual
in_array" title="Zobacz w manualu php" target="_manual
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.