织梦搜索经常会后台看到这个搜索提交的广告和qq号什么的,但是有不规律,无法做到完全屏蔽,但发现可以使用正则匹配来解决这些问题
修改代码如下
打开plus/search.php文件 大约行数73行到77行
if($cfg_notallowstr !='' && preg_match("#".$cfg_notallowstr."#i", $keyword)) { ShowMsg("你的搜索关键字中存在非法内容,被系统禁止!","-1"); exit(); }
添加如下代码
/*防止恶意添加输入不带http:网址url*/ if(preg_match('/w+([-.]w+)*.w+([-.]w+)*/i', $keyword)){ ShowMsg('禁止输入网址地址','-1'); exit(); } /*防止恶意添加输入邮箱地址url*/ if(preg_match('/w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*/i', $keyword)){ ShowMsg('禁止输入邮箱地址','-1'); exit(); } /*防止恶意添加手机广告的电话号码url*/ if(preg_match('/^w+$/i', $keyword)){ ShowMsg('禁止输入英文、数字、下划线组成特殊字符串','-1'); exit(); } /*防止恶意添加手机广告的电话号码url*/ if(preg_match('/^(0|86|17951)?(13[0-9]|15[012356789]|166|17[3678]|18[0-9]|14[57])[0-9]{8}$/i',$keyword)) { ShowMsg('禁止输入数字和手机号','-1'); exit(); } /*防止恶意输入非法网址url*/ $guize= '/^(http|https|ftp)://[A-Za-z0-9]+.[A-Za-z0-9]+[/=?%-&_~`@[]’:+!]*([^<>”])*$/'; if(preg_match($guize,$keyword)) { ShowMsg('禁止输入网址地址','-1'); exit(); }
带来的价值如下
可以防止通过搜索入口,来发布广告和写入特殊字符,给网站少些麻烦,多些真实数据!