Diskuze: Při odeslání zprávy kontrola slova, nevhodné slovo neodeslat
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 12 zpráv z 12.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
tak určite by som na to použil regulárne výrazy. A to jednak v JS(pred odoslaním ajaxu), ALE aj v php(pretože JS si viem vypnúť a posielať zakázané slova aj bez neho).
Jednoducho bud to nejako implementuješ pomocou jQuery pluginu alebo si na to napíšeš vlastnú funkciu. V php je to potom jednoduché. Vo funkcii throwMessage budeš regexom kontrolovať slová a na konci odosielať json v ktorom budeš informovať o úspešnom / neúspešnom(obsahuje zakázané slová) vložení.
Díky za radu, ale jak přesně v throwMessage ty slova kontrolovat?
Nějak takto?
<?php
class Chat extends Core{
public function fetchMessages() {
$this->query("
SELECT `chat`.`message`,
`chat`.`timestamp`,
`chat`.`ip`,
`chat`.`message_id`,
`uzivatele`.`jmeno`,
`uzivatele`. `id`,
`uzivatele`. `admin`
FROM `chat`
JOIN `uzivatele`
ON `chat`.`id` = `uzivatele`.`id`
ORDER BY `chat`.`timestamp`
DESC
");
return $this->rows();
}
public function throwMessage($id, $message){
$adr=$_SERVER["REMOTE_ADDR"];
if(!strstr($message, "heslo")){
$this->query("
INSERT INTO `chat` (`id`, `message`, `timestamp`, `ip`)
VALUES (" . (int)$id.", '" .$this->db->real_escape_string($message) ."', UNIX_TIMESTAMP(), '$adr')
");
}else{
die("Text obsahuje slovo heslo!");
}
}
}
Napadá mě udělat si privátní pole slov (takový blacklist) a v metodě throwMessage() to procházet cyklem a zjišťovat, zda tam takové slovo je. Nevím, jaká funkce je na to nejefektivnější, ale třeba strpos() by mohlo stačit.
private $badWords = array("heslo", "neco", "dalsiho");
// metoda
$wordExists = FALSE;
foreach ($this->badWords as $word) {
if (strpos($message, $word) !== FALSE) {
$wordExists = TRUE;
break;
}
}
// nebo třeba pomocí výjimky
try {
foreach ($this->badWords as $word) {
if (strpos($message, $word) !== FALSE) {
throw new Exception("Text obsahuje slovo {$word}.");
}
}
} catch (Exception $e) {
die($e->getMessage());
}
Tady je na to algoritmus, který vypadá celkem zajímavě
private $badWords = array("heslo", "neco", "dalsiho");
// metoda
$wordExists = FALSE;
foreach ($this->badWords as $word) {
if (strpos($message, $word) !== FALSE) {
$wordExists = TRUE;
break;
}
}
// nebo třeba pomocí výjimky
try {
foreach ($this->badWords as $word) {
if (strpos($message, $word) !== FALSE) {
throw new Exception("Text obsahuje slovo {$word}.");
}
}
} catch (Exception $e) {
die($e->getMessage());
}
Tohle vůbec nevím jak zakomponovat do stávajícího scriptu.
Nicméně děkuji
michales
Píšu to z hlavy, takže nezaručuji, že to bude fungovat, ale udělal bych to
asi takto:
<?php
class Chat extends Core{
private $badWords = array("heslo", "neco", "dalsiho");
public function fetchMessages()
{
...
}
public function throwMessage($id, $message){
$adr=$_SERVER["REMOTE_ADDR"];
try {
foreach ($this->badWords as $word) {
if (strpos($message, $word) !== FALSE) {
throw new Exception("Text obsahuje slovo {$word}.");
}
}
$this->query("
INSERT INTO `chat` (`id`, `message`, `timestamp`, `ip`)
VALUES (" . (int)$id.", '" .$this->db->real_escape_string($message) ."', UNIX_TIMESTAMP(), '$adr')
");
} catch (Exception $e) {
die($e->getMessage());
}
}
}
Neaktivní uživatel
Díky za odkaz
Děkuji, funguje to že to opravdu nepošle zprávu obsahující slova v $badWords ovšem nevypíše to hlášku že Text obsahuje slovo ...
no tak v tej funkcii "outputni" json a v ajaxu si over, či neobsahuje nejakú chybovú hlášku. Každopádne by som to robil regulárnym výrazom + pred porovnávaním by som si ten string prehnal funkciou, čo mi z neho odstráni diakritiku a podobné veci
No script výše uvedený víceméně funguje, jen nevypisuje tu hlášku že bylo použito zakázané slovo
Zobrazeno 12 zpráv z 12.