百度 | 神马 | 搜狗 | 技术文档 | 学习资料分享 - 记录帝国CMS及运维技术的点点滴滴
你的位置:首页 > 实用IT技术 » 正文

【Wordpress相关】WordPress 技巧:用户注册时候不能含有非法关键字

发布时间:2020-09-17

WordPress 技巧:用户注册时候不能含有非法关键字,

我们知道 WordPress 后台 > 设置 > 讨论,可以让我们输入“评论审核”和“评论黑名单”关键字,这些关键字在用户留言的时候将用于非法关键字的检测。那么我们是否可以将这些关键字用于其他方面呢?比如用户注册的时候,用户名不能包含这些非法关键字。答案肯定是可以:

<script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script> <script> (adsbygoogle = window.adsbygoogle || []).push({}); </script>

首先创建非法关键字检测函数:

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 文件即可。


本站推荐使用的主机:,国外主机建议使用

Top