本文實例講述了PHP屏蔽過濾指定關鍵字的方法。分享給大家供大家參考。具體分析如下:
實現思路:
一、把關鍵字專門寫在一個文本文件裡,每行一個,數量不限,有多少寫多少。
二、PHP讀取關鍵字文本,存入一個數組
三、遍歷關鍵字數組,挨個用strpos函數去看看內容有沒有關鍵字,如果有,返回true,沒有則返回false
PHP代碼如下:
復制代碼 代碼如下:/* PHP中用strpos函數過濾關鍵字 */
// 關鍵字過濾函數
function keyWordCheck($content){
// 去除空白
$content = trim($content);
// 讀取關鍵字文本
$content = @file_get_contents('keyWords.txt');
// 轉換成數組
$arr = explode("n", $content);
// 遍歷檢測
for($i=0,$k=count($arr);$i<$k;$i++){
// 如果此數組元素為空則跳過此次循環
if($arr[$i]==''){
continue;
}
// 如果檢測到關鍵字,則返回匹配的關鍵字,並終止運行
if(@strpos($str,trim($arr[$i]))!==false){
//$i=$k;
return $arr[$i];
}
}
// 如果沒有檢測到關鍵字則返回false
return false;
}
$content = '這裡是要發布的文本內容。。。';
// 過濾關鍵字
$keyWord = keyWordCheck($content);
// 判斷是否存在關鍵字
if($keyWord){
echo '你發布的內容存在關鍵字'.$keyWord;
}else{
echo '恭喜!通過關鍵字檢測';
// 往下可以進行寫庫操作完成發布動作。
}
例子2 (注:中文關鍵字過濾時使用的關鍵字文件為utf-8編碼)
復制代碼 代碼如下:/**
* 被禁止的關鍵字檢測
*
* @param string $string 要檢測的字符串
* @param string $fileName 屏蔽關鍵字文件
* @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 = '測試關鍵字';
if ( banwordCheck($content, './banwords.txt') ){
echo "matched! ";
}else{
echo "no match! ";
}
希望本文所述對大家的PHP程序設計有所幫助。
判斷某段文字裡面是否包含某字符串或某些字符串,可以通過preg_match來判斷,對於留言薄或者論壇來說,可以判斷是否包含某些敏感關鍵字,來決定是否過濾,是否允許發表
各敏感詞之間用符號 “|"分割,因為在正則裡面 "|"相當於"或"的意思
<?php
$badkey = "敏感詞|敏感詞B|敏感詞C";
$string = "我是不含有敏感詞的,我要發表";
if(preg_match("/$badkey/i",$string)){
echo "對不起,含有含有敏感字符,不允許發表";
}else{
//do something...
}
?>
而preg_replace則可以用來進行 關鍵詞過濾(髒話過濾)
php可以用preg_replace來過濾髒話
<?php
$badstring="tmd|媽的|TNND|她娘的";
$string="你tmd說什麼,她娘的,不是人";
echo preg_replace("/$badstring/i",'',$string);
?>
<?php
$allergicWord = array('髒話','罵人話');
$str = '這句話裡包含了髒話和罵人話';
for ($i=0;$i<count($allergicWord);$i++){
$content = substr_count($str, $allergicWord[$i]);
if($content>0){
$info = $content;
break;
}
}
if($info>0){
//有違法字符
return TRUE;
}else{
//沒有違法字符
return FALSE;
}
?>
版本:
html>
head>
/head>
form action="" method="post" name="form1" >
input name="word" type="text" />
input name="" type="submit" onclick="return chkValue();" value="確認"/>
/form>
script type="text/javascript">
function chkValue() {
var val = document.form1.word.value,
array = ["acd","svd","fdg","fdk"];
for( var i = array.length; i--;) {
if( val.indexOf( array[i] ) !== -1 ) {
alert('有敏感字符:' + array[i]);
return false;
}
}
return true;
}
/script>
/html>
PHP版本
?php
$content = "afjvahsv sjv sdjavcvacvdjgfsacdaldkfja sfcjasldfj ";
$keyword = array( "acd","svd","fdg","fdk" );
for( $i = count($keyword); $i--; ) {
if( strpos( $content, $keyword[$i] ) !== false ) {
echo "出現敏感字符:{$keyword[$i]}";exit();
}
}
?>
百世歲月當代好 千古江山今朝新 萬象更新