立即注册 找回密码

QQ登录

只需一步,快速开始

查看: 710|回复: 0

[Wordpress 通用教程] WordPress安全运维,后台记录用户注册、最后登录的IP地址的信息

[复制链接]
发表于 2023-12-20 21:18:22 | 显示全部楼层 |阅读模式
道勤网-数据www.daoqin.net

亲注册登录道勤网-可以查看更多帖子内容哦!(包涵精彩图片、文字详情等)请您及时注册登录-www.daoqin.net

您需要 登录 才可以下载或查看,没有账号?立即注册

x
wordpress用户必然会碰到的一个问题,是各种注册、评论机器人会扫描你的网站,并试图发布垃圾评论和文章。而对于多用户的网站,我偶尔会碰到一些有发布权限的用户被泄露了账号密码后,账号就被这些机器人利用起来,在网站发布广告、甚至是违禁内容,如果不是第一时间发现并清理,还可能导致网站被搜索引擎甚至监管部门惩罚,后果严重。通常对于比较重要的网站,你也可以安装Wordfence插件获取一定的保护,但这会牺牲一些服务器资源,导致网站变慢。
除此之外,我推荐的一个比较有效的方式是屏蔽那些会在你网站发布垃圾内容的IP地址,把这些IP地址通过服务器的iptables或者服务商后台的IP黑名单(比如加入阿里云的云盾)来屏蔽。那么问题来了,怎样获取这些IP地址呢?
对于发布垃圾评论的IP地址,这是比较容易的,WordPress后台会记录每条评论发出的IP地址。
01.png
而对于被泄露账户的用户,收集他们的IP地址则需要添加一些代码来做到了。我通过给用户增加2个字段,“signup_ip”和“last_login_ip”来获取需要的信息,代码如下
  1. //用户注册时的IP地址
  2. function brain1981_register_ip($user_id){
  3.         $ip = $_SERVER['REMOTE_ADDR'];
  4.         update_user_meta($user_id, 'signup_ip', $ip);
  5. }
  6. add_action('user_register', 'brain1981_register_ip');
  7. //用户上一次登录的IP地址
  8. function brain1981_last_login_ip( $user_login, $user ) {
  9.         $ip = $_SERVER['REMOTE_ADDR'];
  10.         update_user_meta($user->ID, 'last_login_ip', $ip);
  11. }
  12. add_action('wp_login', 'brain1981_last_login_ip', 10, 2);

  13. //后台增加用户注册时间排序
  14. function brain1981_users_columns( $columns ) {
  15.         $columns['registerdate'] = 'Registered';
  16.         return $columns;
  17. }
  18. add_filter( 'manage_users_columns', 'brain1981_users_columns');

  19. //在列表显示这些信息
  20. function brain1981_users_custom_column( $value, $column_name, $user_id ) {
  21.         if ( 'registerdate' != $column_name ) {
  22.                 return $value;
  23.         } else {
  24.                 $user = get_userdata( $user_id );
  25.                 $signup_ip = get_user_meta($user_id, 'signup_ip', true);
  26.                 if ($signup_ip == ""){ $signup_ip = '<em>N/A</em>'; }

  27.                 $last_login_ip = get_user_meta($user_id, 'last_login_ip', true);
  28.                 if ($last_login_ip == ""){ $last_login_ip = '<em>N/A</em>'; }
  29.                 $formated_date = __( 'Y/m/d g:i:s' );
  30.                 $registered   = strtotime( get_date_from_gmt( $user->user_registered ) );
  31.                 $registerdate = '<span>'. date_i18n( $formated_date, $registered ) .'</span><br/>Signup IP:'.$signup_ip.'<br/>Last Login IP:'.$last_login_ip ;
  32.                 return $registerdate;
  33.         }
  34. }
  35. add_action( 'manage_users_custom_column', 'brain1981_users_custom_column', 10, 3);

  36. //使这一栏可以参与后台排序,通过用户注册时间排序
  37. function brain1981_users_sortable_columns( $columns ) {
  38.         $custom = array(
  39.                 'registerdate' => 'registered',
  40.         );
  41.         return wp_parse_args( $custom, $columns );
  42. }
  43. add_filter( 'manage_users_sortable_columns', 'brain1981_users_sortable_columns' );
复制代码
这样后台就会列出这些信息了。注册时间可以直接显示出来,因为WP本身有记录,但是IP地址则是需要用户新注册和下次登录才会有了,因为这些都是当前才开始记录的数据 。
02.png
获取这些IP后,如果发现这个用户会发垃圾内容,判断Ta的账号有问题,就可以屏蔽上次登录的IP和他的权限。需要通知他可能在网上的各种账号都已有被泄露的风险,通常是被撞库了,一定要立即修改密码。
对于访问量比较大的网站,甄别出来的机器人IP我通常是逐条屏蔽,


道勤主机提供365天*24小时全年全天无休、实时在线、零等待的售后技术支持。竭力为您免费处理您在使用道勤主机过程中所遇到的一切问题! 如果您是道勤主机用户,那么您可以通过QQ【792472177】、售后QQ【59133755】、旺旺【诠释意念】、微信:q792472177免费电话、后台提交工单这些方式联系道勤主机客服! 如果您不是我们的客户也没问题,点击页面最右边的企业QQ在线咨询图标联系我们并购买后,我们为您免费进行无缝搬家服务,让您享受网站零访问延迟的迁移到道勤主机的服务!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

道勤网- 推荐内容!上一条 /2 下一条

!jz_fbzt! !jz_sgzt! !jz_xgzt! 快速回复 !jz_fhlb! !jz_lxwm! !jz_gfqqq!

关于我们|手机版|小黑屋|地图|【道勤网】-www.daoqin.net 软件视频自学教程|免费教程|自学电脑|3D教程|平面教程|影视动画教程|办公教程|机械设计教程|网站设计教程【道勤网】 ( 皖ICP备15000319号-1 )

GMT+8, 2024-5-3 11:57

Powered by DaoQin! X3.4 © 2016-2063 Dao Qin & 道勤科技

快速回复 返回顶部 返回列表