比如要拦截掉:刷票,投票,涨票,拉票。
还有两端匹配:微信,或者 微xxxx信。
先不考虑性能,实现一个简单版本的。
public function checkNicknameAllow($nickName, $checkPhone = true)
{
// 手机号
if($checkPhone && preg_match("/1.*[3-8]+.*\d+.*\d+.*\d+.*\d+.*\d+.*\d+.*\d+.*\d+.*\d+/", $nickName)){
return false;
}
foreach(Video2Filter::query()->orderBy('sort', 'asc')->cursor() as $v){
$v['name'] = str_replace('+', '.*', $v['name']);
if(preg_match("/{$v['name']}/", $nickName)){
return false;
}
}
return true;
}
数据结果
CREATE TABLE `video2_filter` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(255) DEFAULT '',
`type` tinyint(4) DEFAULT '1',
`sort` int(11) DEFAULT '9999',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8;
INSERT INTO `opdata`.`video2_filter` (`id`, `name`, `type`, `sort`) VALUES ('9', '涨|刷|投|票', '1', '1');
INSERT INTO `opdata`.`video2_filter` (`id`, `name`, `type`, `sort`) VALUES ('5', '微信', '1', '2');
INSERT INTO `opdata`.`video2_filter` (`id`, `name`, `type`, `sort`) VALUES ('7', 'wx', '1', '3');
INSERT INTO `opdata`.`video2_filter` (`id`, `name`, `type`, `sort`) VALUES ('10', '微+信', '1', '9999');