当前位置:首页>WordPress建站>用户交互>WordPress 在用户列表记录用户注册时的IP地址

WordPress 在用户列表记录用户注册时的IP地址

对于像 WordPress大学 这样开放注册的站点,经常都会受到批量垃圾注册攻击,虽然有一些很容易就识别出是垃圾用户,但是有一些还是很难确保的。我们可以通过记录用户注册时的IP地址,帮助我们进一步判断是不是垃圾用户。

Register IP 就是一个记录用户注册的IP的插件,支持单站点和多站点,只有管理员才可以查看到用户的IP。你只需在后台搜索 register-ip-multisite 即可在线安装,或者在这里下载

倡萌看了一下它的源代码,发现可以提取出来,精简了一下,将代码添加到主题的 functions.php 即可

  1. /**
  2. * WordPress 在用户列表记录用户注册时的IP地址
  3. * https://www.wpdaxue.com/register-ip-multisite.html
  4. */
  5. // 添加一个字段保存IP地址
  6. function log_ip($user_id){
  7. $ip = $_SERVER['REMOTE_ADDR'];
  8. update_user_meta($user_id, 'signup_ip', $ip);
  9. }
  10. add_action('user_register', 'log_ip');
  11.  
  12. // 添加“IP地址”这个栏目
  13. function signup_ip($column_headers) {
  14. $column_headers['signup_ip'] = __('IP地址', 'signup_ip');
  15. return $column_headers;
  16. }
  17. if ( is_multisite() ) {
  18. // 添加多站点支持
  19. add_filter('wpmu_users_columns', 'signup_ip');
  20. } else {
  21. // 添加单站点支持
  22. add_filter('manage_users_columns', 'signup_ip');
  23. }
  24.  
  25. // 格式化输出内容
  26. function ripms_columns($value, $column_name, $user_id) {
  27. if ( $column_name == 'signup_ip' ) {
  28. $ip = get_user_meta($user_id, 'signup_ip', true);
  29. if ($ip != ""){
  30. $ret = '<em>'.__($ip, 'signup_ip').'</em>';
  31. return $ret;
  32. } else {
  33. $ret = '<em>'.__('没有记录', 'signup_ip').'</em>';
  34. return $ret;
  35. }
  36. }
  37. return $value;
  38. }
  39. add_action('manage_users_custom_column', 'ripms_columns', 10, 3);

下面分享一下WordPress大学目前使用的综合版代码(已包含上面的功能,不要同时使用),支持显示用户昵称、网站、注册时间、注册IP、最近登录时间、登录IP,默认按照注册时间排序:

user-columns-wpdaxue_com

将代码添加到主题的 functions.php 即可

  1. /**
  2. * WordPress 后台用户列表显示额外信息
  3. * https://www.wpdaxue.com/register-ip-multisite.html
  4. */
  5. // 创建一个新字段存储用户注册时的IP地址
  6. add_action('user_register', 'log_ip');
  7. function log_ip($user_id){
  8. $ip = $_SERVER['REMOTE_ADDR'];
  9. update_user_meta($user_id, 'signup_ip', $ip);
  10. }
  11. // 创建新字段存储用户登录时间和登录IP
  12. add_action( 'wp_login', 'insert_last_login' );
  13. function insert_last_login( $login ) {
  14. global $user_id;
  15. $user = get_userdatabylogin( $login );
  16. update_user_meta( $user->ID, 'last_login', current_time( 'mysql' ) );
  17. $last_login_ip = $_SERVER['REMOTE_ADDR'];
  18. update_user_meta( $user->ID, 'last_login_ip', $last_login_ip);
  19. }
  20. // 添加额外的栏目
  21. add_filter('manage_users_columns', 'add_user_additional_column');
  22. function add_user_additional_column($columns) {
  23. $columns['user_nickname'] = '昵称';
  24. $columns['user_url'] = '网站';
  25. $columns['reg_time'] = '注册时间';
  26. $columns['last_login'] = '上次登录';
  27. // 打算将注册IP和注册时间、登录IP和登录时间合并显示,所以我注销下面两行
  28. /*$columns['signup_ip'] = '注册IP';
  29. $columns['last_login_ip'] = '登录IP';*/
  30. unset($columns['name']);//移除“姓名”这一栏,如果你需要保留,删除这行即可
  31. return $columns;
  32. }
  33. //显示栏目的内容
  34. add_action('manage_users_custom_column', 'show_user_additional_column_content', 10, 3);
  35. function show_user_additional_column_content($value, $column_name, $user_id) {
  36. $user = get_userdata( $user_id );
  37. // 输出“昵称”
  38. if ( 'user_nickname' == $column_name )
  39. return $user->nickname;
  40. // 输出用户的网站
  41. if ( 'user_url' == $column_name )
  42. return '<a href="'.$user->user_url.'" target="_blank">'.$user->user_url.'</a>';
  43. // 输出注册时间和注册IP
  44. if('reg_time' == $column_name ){
  45. return get_date_from_gmt($user->user_registered) .'<br />'.get_user_meta( $user->ID, 'signup_ip', true);
  46. }
  47. // 输出最近登录时间和登录IP
  48. if ( 'last_login' == $column_name && $user->last_login ){
  49. return get_user_meta( $user->ID, 'last_login', ture ).'<br />'.get_user_meta( $user->ID, 'last_login_ip', ture );
  50. }
  51. return $value;
  52. }
  53. // 默认按照注册时间排序
  54. add_filter( "manage_users_sortable_columns", 'cmhello_users_sortable_columns' );
  55. function cmhello_users_sortable_columns($sortable_columns){
  56. $sortable_columns['reg_time'] = 'reg_time';
  57. return $sortable_columns;
  58. }
  59. add_action( 'pre_user_query', 'cmhello_users_search_order' );
  60. function cmhello_users_search_order($obj){
  61. if(!isset($_REQUEST['orderby']) || $_REQUEST['orderby']=='reg_time' ){
  62. if( !in_array($_REQUEST['order'],array('asc','desc')) ){
  63. $_REQUEST['order'] = 'desc';
  64. }
  65. $obj->query_orderby = "ORDER BY user_registered ".$_REQUEST['order']."";
  66. }
  67. }

最后说一下,如果你和WordPress大学一样使用前端用户注册页面,不妨使用“验证问题”来代替“验证码”,至少倡萌使用这个方法以后,几乎没有遇到机器批量注册垃圾用户的情况了!添加方法请移步:WordPress 注册表单添加验证问题(支持多个随机问题)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
欢迎关注WordPress大学公众号 WPDAXUE
用户交互

WordPress 有趣的评论验证码插件:Fancy Captcha

2013-12-16 7:55:09

用户交互

让 WordPress 完美拥有论坛功能

2013-12-21 12:31:29

4 条回复 A文章作者 M管理员
欢迎您,新朋友,感谢参与互动!
  1. 如何增加 按文章数量排序 求告知 🙁

  2. 怎么将「个人设置」页面里的「姓氏」一栏改成其他内容,如改开「English Name」~~~

  3. 請問倡萌,如果網站有使用CloudFlare這類的CDN或是架站在OpenShift雲空間,這段代碼是否能夠抓取到用戶的真實IP。是否需要用類似下方代碼改寫判斷?
    if (!empty($_SERVER[‘HTTP_CLIENT_IP’]))
    {
    $ip=$_SERVER[‘HTTP_CLIENT_IP’];
    }
    else if (!empty($_SERVER[‘HTTP_X_FORWARDED_FOR’]))
    {
    $ip=$_SERVER[‘HTTP_X_FORWARDED_FOR’];
    }
    else
    {
    $ip=$_SERVER[‘REMOTE_ADDR’];
    }

    • 如果使用了CDN,应该是不能直接获取真实IP的,你自己测试一下你的修改方案,看看是否有效,欢迎反馈测试结果

个人中心
购物车
优惠劵
今日签到
私信列表
搜索