WordPress 技巧:用户注册时候不能含有非法关键字
我们知道 WordPress 后台 > 设置 > 讨论,可以让我们输入“评论审核”和“评论黑名单”关键字,这些关键字在用户留言的时候将用于非法关键字的检测。那么我们是否可以将这些关键字用于其他方面呢?比如用户注册的时候,用户名不能包含这些非法关键字。答案肯定是可以:
首先创建非法关键字检测函数:
function wpjam_blacklist_check($str){
$moderation_keys = trim(get_option('moderation_keys'));
$blacklist_keys = trim(get_option('blacklist_keys'));
$keys = $moderation_keys ."\n".$blacklist_keys;
$words = explode("\n", $keys );
foreach ( (array) $words as $word) {
$word = trim($word);
// Skip empty lines
if ( empty($word) )
continue;
// Do some escaping magic so that '#' chars in the
// spam words don't break things:
$word = preg_quote($word, '#');
$pattern = "#$word#i";
if ( preg_match($pattern, $str) ) return true;
}
return false;
}
设置用户名不能含有待审关键字和黑名单关键字。
add_filter( 'sanitize_user', 'wpjam_sanitize_user',3,3);
function wpjam_sanitize_user($username, $raw_username, $strict){
if(wpjam_blacklist_check($username)){
$username = '';
}
return $username;
}
将上面这两段函数复制到当前主题的 functions.php
文件即可。