ucenter中詞語過濾原理分析
本文分析了ucenter中詞語過濾原理。分享給大家供大家參考,具體如下:
過濾詞語表:
id | admin | find | replacement | findpattern |
1 | UCenterAdminist | 訪問 | 大 | /訪問/is |
2 | UCenterAdminist | 4655 | 45 | /4655/is |
3 | UCenterAdminist | fdsaf | dfsa | /fdsaf/is |
4 | UCenterAdminist | 有機會 | 在 | /有機會/is |
組建緩存數(shù)據(jù):
//private function _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() 的每個參數(shù)(除了 limit)都可以是一個數(shù)組。如果 pattern 和 replacement 都是數(shù)組,將以其鍵名在數(shù)組中出現(xiàn)的順序來進行處理。這不一定和索引的數(shù)字順序相同。如果使用索引來標識哪個 pattern 將被哪個 replacement 來替換,應該在調(diào)用 preg_replace() 之前用 ksort() 對數(shù)組進行排序。
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《php安全過濾技巧總結(jié)》、《PHP運算與運算符用法總結(jié)》、《PHP網(wǎng)絡編程技巧總結(jié)》、《PHP基本語法入門教程》、《php面向?qū)ο蟪绦蛟O計入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
PHP用strstr()函數(shù)阻止垃圾評論(通過判斷a標記)
假如你的網(wǎng)站垃圾評論很多,大部分垃圾評論是帶鏈接的,因為要增加反向鏈接嘛,所以你可以使用下面的小技巧來杜絕這些帶鏈接的垃圾評論2013-09-09php中ftp_chdir與ftp_cdup函數(shù)用法
這篇文章主要介紹了php中ftp_chdir與ftp_cdup函數(shù)用法,以實例形式講述了PHP中的FTP目錄操作技巧,具有一定的借鑒價值,需要的朋友可以參考下2014-11-11linux下的php-fpm參數(shù)配置介紹與參數(shù)優(yōu)化說明
本文主要講解了在linux下php-fpm一些重要參數(shù)的中文詳細說明,并詳細介紹了php-fpm關于性能方面的參數(shù)優(yōu)化介紹2017-12-12