Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
mam
$wpis = $_POST['wpis']; $word_array=file('wulgaryzmy.txt'); foreach($word_array as $brzydkie_slowo) { if(eregi($brzydkie_slowo, $wpis)) { echo "jest brzydkie słowo"; } else { } }
I chociaż jest brzydkie słowo to nie działa. W pliku wulgaryzmy mam wypisane przekleństwa.
Jad dam
$wpis = 'chuj' $word_array=file('wulgaryzmy.txt'); foreach($word_array as $brzydkie_slowo) { if(eregi($brzydkie_slowo, $wpis)) { echo "jest brzydkie słowo"; } else { } }
I chociaż ch** jest na liście to nie działa. Ma ktoś pomysł jak to zrobić żeby działało? Ogólnie mi chodzi o to żeby jak pojawi się przekleństwo w $wpis to nie wyśle wpisu do bazy i wyświetli odpowiedni komunikat.
Offline
Wyświetl sobie $word_array przy pomocy print_r() na przykład. Zobaczysz czy dobrze plik wczytuje do tabeli, może z tym jest problem, złe znaki końca linii czy coś.
Offline
wyświetlałem za pomocą echo i było wszystko ok
Offline
A nie powinna być zamieniona kolejnośc w eregi?
Offline
ja bym proponowal po prostu:
$wpis = 'marchewka'; $word_array=file('wulgaryzmy.txt'); if( in_array($wpis, $word_array) ){ echo "jest brzydkie słowo"; }
ok, powyzszy sposob jest dobry dla porownania czy dane slowo jest brzydkie, ale gdy szukamy brzydkich slow w tekscie, sposob ten jest malo optymalny. Napisalem zatem cos na podstawie Twojego skryptu, w takiej formie mi dziala:
<? $wpis = $_GET['wpis']; $word_array=file('wulgaryzmy.txt'); print_r($word_array); foreach($word_array as $brzydkie_slowo) { $newline = array("\n", "\r"); $brzydkie_slowo = str_replace($newline, "", $brzydkie_slowo); if(preg_match('/'.$brzydkie_slowo.'/', $wpis)) { echo "jest brzydkie słowo"; } else { } }?>
powyzej usuwam z brzydkiego slowa znak nowej linii oraz powrót karetki na pusty znak, poniewaz okazalo się, że funkcja file() zczytuje do tablicy wiersze wraz ze znakami nowej linii oraz powrotem karetki.
Ostatnio edytowany przez grzegorz.85 (2009-10-08 00:45:24)
Offline
No teraz pokazuje że jest brzydkie słowo. Ale pokazuje że ono jest nawet jak go nie ma ;D
Offline
[quote=giegiel]No teraz pokazuje że jest brzydkie słowo. Ale pokazuje że ono jest nawet jak go nie ma ;D[/quote]
Teraz to znaczy co zrobiłeś? Użyłeś sposobu grzegorza czy poprawiłeś eregi w swoim kodzie? Co do in_array, które jako przykład podał grzegorze jest troche do pupy bo porównuje z zachowaniem wielkości liter. Twój sposób wydaje się najlepszy, tylko zmień to eregi jak trzeba i może daj w trim porównywane stringi.
Offline
Ni sposób od Grzegorza tak działa/nie działa :) potem się pobawie z tym eregi ;D teraz czas na uczelnie.
Offline
Zmieniłem kolejność w eregi i działa ;) Dzięki
Offline
A i czopka nie działa.... mam tak
$imie_nazwisko = $_POST['imie_nazwisko']; $email = $_POST['email']; $wpis = $_POST['wpis']; $word_array=file('wulgaryzmy.txt'); $brz=0; foreach($word_array as $brzydkie_slowo) { if(eregi($wpis, $brzydkie_slowo)) { $brz=1; } else { } } if($brz == 0) { $dodanie = "INSERT INTO wpisy ( imie_nazwisko, email, wpis, data) VALUES ('$imie_nazwisko' , '$email' , '$wpis', NOW())"; $wynik = mysql_query($dodanie) or die (mysql_error()); echo "Wpis dodano pomyślnie"; } else { echo "Komentarz zawiera wulgaryzmy, nie zostanie opublikowany."; }
i jak wpiszę
zajebiście[/quote]
to nie przepuszcza ale jak wpiszębunkrów nie ma ale też jest zajebiście[/quote]
to przepuszcza ;/Offline
Bo cały wpis "bunkrów nie ma ale też jest zajebiście" próbuje znaleźć. Musisz rozbić ciąg na słowa i każde słowo sprawdzać oddzielnie czy jest wulgaryzmem. Albo paradoksalnie ;] zamienić kolejność w eregi na taką jak była. Ale wszystko pod warunkiem, że w wulgaryzmy.txt każdy wulgaryzm jest w oddzielnej linii i przy porównaniu użyj trim() czyli eregi(trim($brzydkie_slowo), $wpis).
Offline
Działa dzięki :D
Offline
Time (s) | Query |
---|---|
0.00020 | SET CHARSET latin2 |
0.00005 | SET NAMES latin2 |
0.00118 | SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.135.187.210' WHERE u.id=1 |
0.00077 | REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '3.135.187.210', 1727030372) |
0.00050 | SELECT * FROM punbb_online WHERE logged<1727030072 |
0.00070 | SELECT topic_id FROM punbb_posts WHERE id=129939 |
0.00216 | SELECT id FROM punbb_posts WHERE topic_id=15152 ORDER BY posted |
0.00064 | SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=15152 AND t.moved_to IS NULL |
0.00006 | SELECT search_for, replace_with FROM punbb_censoring |
0.00099 | SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=15152 ORDER BY p.id LIMIT 0,25 |
0.00112 | UPDATE punbb_topics SET num_views=num_views+1 WHERE id=15152 |
Total query time: 0.00837 s |