PHP屏蔽過(guò)濾指定關(guān)鍵字的方法
本文實(shí)例講述了PHP屏蔽過(guò)濾指定關(guān)鍵字的方法。分享給大家供大家參考。具體分析如下:
實(shí)現(xiàn)思路:
一、把關(guān)鍵字專門(mén)寫(xiě)在一個(gè)文本文件里,每行一個(gè),數(shù)量不限,有多少寫(xiě)多少。
二、PHP讀取關(guān)鍵字文本,存入一個(gè)數(shù)組
三、遍歷關(guān)鍵字?jǐn)?shù)組,挨個(gè)用strpos函數(shù)去看看內(nèi)容有沒(méi)有關(guān)鍵字,如果有,返回true,沒(méi)有則返回false
PHP代碼如下:
// 關(guān)鍵字過(guò)濾函數(shù)
function keyWordCheck($content){
// 去除空白
$content = trim($content);
// 讀取關(guān)鍵字文本
$content = @file_get_contents('keyWords.txt');
// 轉(zhuǎn)換成數(shù)組
$arr = explode("n", $content);
// 遍歷檢測(cè)
for($i=0,$k=count($arr);$i<$k;$i++){
// 如果此數(shù)組元素為空則跳過(guò)此次循環(huán)
if($arr[$i]==''){
continue;
}
// 如果檢測(cè)到關(guān)鍵字,則返回匹配的關(guān)鍵字,并終止運(yùn)行
if(@strpos($str,trim($arr[$i]))!==false){
//$i=$k;
return $arr[$i];
}
}
// 如果沒(méi)有檢測(cè)到關(guān)鍵字則返回false
return false;
}
$content = '這里是要發(fā)布的文本內(nèi)容。。。';
// 過(guò)濾關(guān)鍵字
$keyWord = keyWordCheck($content);
// 判斷是否存在關(guān)鍵字
if($keyWord){
echo '你發(fā)布的內(nèi)容存在關(guān)鍵字'.$keyWord;
}else{
echo '恭喜!通過(guò)關(guān)鍵字檢測(cè)';
// 往下可以進(jìn)行寫(xiě)庫(kù)操作完成發(fā)布動(dòng)作。
}
例子2 (注:中文關(guān)鍵字過(guò)濾時(shí)使用的關(guān)鍵字文件為utf-8編碼)
* 被禁止的關(guān)鍵字檢測(cè)
*
* @param string $string 要檢測(cè)的字符串
* @param string $fileName 屏蔽關(guān)鍵字文件
* @return bool
*/
function banwordCheck( $string, $fileName )
{
if ( !($words = file_get_contents( $fileName )) ){
die('file read error!');
}
$string = strtolower($string);
$matched = preg_match('/'.$words.'/i', $string, $result);
if ( $matched && isset($result[0]) && strlen($result[0]) > 0 )
{
if ( strlen($result[0]) == 2 ){
$matched = preg_match('/'.$words.'/iu', $string, $result);
}
if ( $matched && isset($result[0]) && strlen($result[0]) > 0 ) {
return true;
}else{
return false;
}
}else{
return false;
}
}
$content = '測(cè)試關(guān)鍵字';
if ( banwordCheck($content, './banwords.txt') ){
echo "matched! ";
}else{
echo "no match! ";
}
希望本文所述對(duì)大家的PHP程序設(shè)計(jì)有所幫助。
- php過(guò)濾敏感詞的示例
- PHP正則過(guò)濾處理微信昵稱中emoji字符的方法
- php過(guò)濾輸入操作之htmlentities與htmlspecialchars用法分析
- PHP數(shù)據(jù)的提交與過(guò)濾基本操作實(shí)例詳解
- PHP簡(jiǎn)單字符串過(guò)濾方法示例
- PHP Filter過(guò)濾器全面解析
- PHP正則表達(dá)式過(guò)濾html標(biāo)簽屬性(DEMO)
- 整理php防注入和XSS攻擊通用過(guò)濾
- PHP開(kāi)發(fā)不能違背的安全規(guī)則 過(guò)濾用戶輸入
- php過(guò)濾所有惡意字符(批量過(guò)濾post,get敏感數(shù)據(jù))
- PHP實(shí)現(xiàn)的敏感詞過(guò)濾方法示例
相關(guān)文章
PHP+HTML+JavaScript+Css實(shí)現(xiàn)簡(jiǎn)單爬蟲(chóng)開(kāi)發(fā)
這篇文章主要為大家詳細(xì)介紹了PHP+HTML+JavaScript+Css實(shí)現(xiàn)簡(jiǎn)單爬蟲(chóng)開(kāi)發(fā),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-03-03非集成環(huán)境的php運(yùn)行環(huán)境(Apache配置、Mysql)搭建安裝圖文教程
這篇文章主要介紹了非集成環(huán)境的php運(yùn)行環(huán)境(Apache配置、Mysql)搭建安裝圖文教程,感興趣的小伙伴們可以參考一下2016-04-04Php Mssql操作簡(jiǎn)單封裝支持存儲(chǔ)過(guò)程
沒(méi)有啥太多的功能,就是簡(jiǎn)單封裝,也沒(méi)有緩存,平時(shí)用ezSQL,但是ezSQL不支持存儲(chǔ)過(guò)程,所以這里封裝了存儲(chǔ)過(guò)程,因?yàn)樽约旱男枰皇亲鲆粋€(gè)標(biāo)記在這里而已。2009-12-12/etc/php-fpm.d/www.conf 配置注意事項(xiàng)
下面小編就為大家?guī)?lái)一篇/etc/php-fpm.d/www.conf 配置注意事項(xiàng)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02