本文分析了ucenter中詞語(yǔ)過(guò)濾原理。分享給大家供大家參考,具體如下:
過(guò)濾詞語(yǔ)表:
| id | admin | find | replacement | findpattern |
| 1 | UCenterAdminist | 訪問 | 大 | /訪問/is |
| 2 | UCenterAdminist | 4655 | 45 | /4655/is |
| 3 | UCenterAdminist | fdsaf | dfsa | /fdsaf/is |
| 4 | UCenterAdminist | 有機(jī)會(huì) | 在 | /有機(jī)會(huì)/is |
組建緩存數(shù)據(jù):
//privatefunction _get_badwords() { $data = $this->db->fetch_all("SELECT * FROM ".UC_DBTABLEPRE."badwords"); $return = array(); if(is_array($data)) { foreach($data as $k => $v) { $return['findpattern'][$k] = $v['findpattern']; $return['replace'][$k] = $v['replacement']; } } return $return;}
調(diào)用方法:
$_CACHE['badwords'] = $this->base->cache('badwords');if($_CACHE['badwords']['findpattern']) { $subject = @preg_replace($_CACHE['badwords']['findpattern'], $_CACHE['badwords']['replace'], $subject); $message = @preg_replace($_CACHE['badwords']['findpattern'], $_CACHE['badwords']['replace'], $message);}preg_replace() 的每個(gè)參數(shù)(除了 limit)都可以是一個(gè)數(shù)組。如果 pattern 和 replacement 都是數(shù)組,將以其鍵名在數(shù)組中出現(xiàn)的順序來(lái)進(jìn)行處理。這不一定和索引的數(shù)字順序相同。如果使用索引來(lái)標(biāo)識(shí)哪個(gè) pattern 將被哪個(gè) replacement 來(lái)替換,應(yīng)該在調(diào)用 preg_replace() 之前用 ksort() 對(duì)數(shù)組進(jìn)行排序。
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選