敏感词过滤01

版权声明:俗世凡人行(释) QQ:748507607 https://blog.csdn.net/weixin_41887155/article/details/88692150
<?php
//敏感词案例
  $string = 'likeyou小白喜欢小黑爱着的大黄'; //要过滤的内容
  $list = ['小明', '小红', '大白', '大黄', '小黑', 'me', 'you'];  //定义敏感词数组
  $result = sensitive($list, $string);
  echo ($result);
  die;
  //打印结果:
  /*
    原句为 [ likeyou小白喜欢小黑爱着的大黄 ]
    匹配到 [ 3 ]个敏感词:[ you,小黑,大黄 ]
    替换后为:[ like*小白喜欢*爱着的* ]
    */

/**
 * @todo 敏感词过滤,返回结果
 * @param array $list  定义敏感词一维数组
 * @param string $string 要过滤的内容
 * @return string $log 处理结果
 */
function sensitive($list, $string)
{
  $count = 0; //违规词的个数
  $sensitiveWord = '';  //违规词
  $stringAfter = $string;  //替换后的内容
  $pattern = "/".implode("|",$list)."/i"; //定义正则表达式
  if(preg_match_all($pattern, $string, $matches)){ //匹配到了结果
    $patternList = $matches[0];  //匹配到的数组
    $count = count($patternList);
    $sensitiveWord = implode(',', $patternList); //敏感词数组转字符串
    //把匹配到的数组进行合并,替换使用
    $replaceArray = array_combine($patternList,array_fill(0,count($patternList),'*'));
    $stringAfter = strtr($string, $replaceArray); //结果替换
  }
  $log = "原句为 [ {$string} ]<br/>";
  if($count==0){
    $log .= "暂未匹配到敏感词!";
  }else{
    $log .= "匹配到 [ {$count} ]个敏感词:[ {$sensitiveWord} ]<br/>".
      "替换后为:[ {$stringAfter} ]";
  }
  return $log;
}


猜你喜欢

转载自blog.csdn.net/weixin_41887155/article/details/88692150