php怎么过滤关键字,PHP屏蔽过滤指定关键字的方法,php屏蔽过滤关键字_PHP教程...

PHP屏蔽过滤指定关键字的方法,php屏蔽过滤关键字

本文实例讲述了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

// 如果此数组元素为空则跳过此次循环

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 ‘恭喜!通过关键字检测’;

// 往下可以进行写库操作完成发布动作。

}$k;$i++){

例子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程序设计有所帮助。

我想通过php代码屏蔽一些敏感词,写了断代码,老是错误

判断某段文字里面是否包含某字符串或某些字符串,可以通过preg_match来判断,对于留言薄或者论坛来说,可以判断是否包含某些敏感关键字,来决定是否过滤,是否允许发表

各敏感词之间用符号 “|”分割,因为在正则里面 “|”相当于”或”的意思

$badkey = “敏感词|敏感词B|敏感词C”;

$string = “我是不含有敏感词的,我要发表”;

if(preg_match(“/$badkey/i”,$string)){

echo “对不起,含有含有敏感字符,不允许发表”;

}else{

//do something…

}

?>

而preg_replace则可以用来进行 关键词过滤(脏话过滤)

php可以用preg_replace来过滤脏话

$badstring=”tmd|妈的|TNND|她娘的”;

$string=”你tmd说什么,她娘的,不是人”;

echo preg_replace(“/$badstring/i”,”,$string);

?>

$allergicWord = array(‘脏话’,’骂人话’);

$str = ‘这句话里包含了脏话和骂人话’;

for ($i=0;$i

$content = substr_count($str, $allergicWord[$i]);

if($content>0){

$info = $content;

break;

}

}

if($info>0){

//有违法字符

return TRUE;

}else{

//没有违法字符

return FALSE;

}

?>

php怎用实现关键词屏蔽?用 js 或者 ajax 也可以

版本:

html>

head>

/head>

form action=”” method=”post” name=”form1″ >

input name=”word” type=”text” />

input name=”” type=”submit” οnclick=”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();

}

}

?>

百世岁月当代好 千古江山今朝新 万象更新

www.bkjia.comtrueTechArticlePHP屏蔽过滤指定关键字的方法,php屏蔽过滤关键字 本文实例讲述了PHP屏蔽过滤指定关键字的方法。分享给大家供大家参考。具体分析如下:…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值