/*
PHP中用strpos
函数过滤关键字 */
// 关键字过滤
函数
function keyWordCheck($content){
//
去除空白
$content = trim($content);
// 读取关键字文本
$content = @
file_get_contents&
#40;'keyWo
rds.txt');
// 转换成数组
$arr =
explode("n",$content);
// 遍历检测
for($i=0,$k=count($arr);$i<$k;$@R_
406_2563@){
// 如果此数组元素为空则跳过此次循环
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 '恭喜!通过关键字检测';
// 往下可以进行写库操作完成发布动作.
}
/**
* 被
禁止的关键字检测
*
* @par
am 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]) &am
p;&
strlen($result[0]) > 0 )
{
if ( strlen($result[0]) == 2 ){
$matched = preg_match('/'.$words.'/iu',$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! ";
}