User Spam Remover is a plugin for WordPress that automatically removes spam user registrations and other old, never-used user accounts. It also blocks the notification e-mail that WordPress normally sends to the administrator whenever a new user registers (annoying when that registration is spam!) and logs it instead.
The plugin adds a configuration panel so that all of these options can be turned on or off, and it logs and fully backs up all user accounts that it deletes, so that you can restore them if you need to.
Automatically deletes user registration spam and other orphaned, never-used accounts.
Very simple, enable and go! Doesn’t interfere with the normal user registration process in any way. So, it doesn’t add captchas or activation or anything else — you’re free to use it alongside a plugin that does, if you like.
Blocks notification e-mail that WordPress normally sends to the administrator every time a new user registers (instead, logs this event).
Fully configurable, with grace period for new accounts and optional username whitelist.
Fully logs all actions and backs up all user accounts that it deletes so that you can seamlessly restore them if you ever need to.
Please see requirements and installation instructions below, or online in the WordPress support forum.
For more information, please go to: https://lyncd.com/user-spam-remover/
Please see the updated FAQ online at: https://lyncd.com/user-spam-remover/faq/
- Installation Instructions
PHP 5.1+ (tested with PHP 5.2-7.0)
MySQL using PHP mysqli extension (read on for details)
If you are strictly assigning MySQL privileges, note that the plugin adds two column indexes, so your database account must be assigned the ALTER and CREATE privileges (if you don’t know what this means, don’t worry, you probably already have this).
Download, unzip and upload into your plugins directory. (Or, install through the plugins menu in WordPress.)
Go to the Plugins configuration screen in WordPress and activate. Look for the settings link to go to the User Spam Remover settings page (User Spam Remover also gets added to the left menu under “Users”).
Note: if you see mysqli errors at the top of the activation or settings page, you need to tell WordPress use use the
mysqliextension instead of the older
mysqlone. Add this line to your
wp-config.php(insert it next to all the other DB settings, near the top):
On the settings page, you’ll need to click the “Enable” checkbox to turn the plugin on. Scroll down and change any options you like. Click “Save Changes.”
One note on logging: By default, all logging is enabled (good!), but the log directory is set to the
logsubdirectory of the plugin. While this is OK, it means your log files will be viewable over the web, so I recommend you change this directory to someplace else (i.e., if the root of your site is
/www/mysite/html, do something like
/www/mysite/log). Be sure to use
chmodor your FTP program to make this directory webserver-writable (don’t worry, User Spam Remover will warn you if it’s not).
Once you’re done, that’s it! Feel free to use the blue “Remove spam/unused accounts now” button to test it out. User Spam Remover will run once a day automatically from now on.
Exactly what I needed. Would be nicer if it worked out of the box. The mysqli fix is easy for someone like me but would be a big hindrance to less geeky types.
Tried activating. Says ‘Failed due to Fatal error’
Does not work with many WordPress sites throwing a fatal error about mysqli.
A friend’s blog had “Let anyone register” enabled for quite some time and accumulated over 3,000 spam accounts. Installed this, went to its settings page and enabled it.
I appreciated it having a comma-separated whitelist and that the plugin listed the accounts it would delete with a 48 hour delay while providing a button to do it immediately.
Each button press removed 1k of the accounts quickly, and I pressed it a few more times and removed every non-active account on the site immediately.
Since we’re no longer allowing new registrations, I didn’t need the other features, so the plugin was disabled after doing its job securely, quickly, and easily.
Great way to clean a long running site of “junk” users.
Removed over 29k in minutes..
Contributors & Developers
“User Spam Remover” is open source software. The following people have contributed to this plugin.Contributors
- Bump to 1.0. No changes to core functionality. For existing users there is no urgent reason to upgrade to this version.
- Improved error message when
mysqliis not enabled.
- Reformat of readme.txt due to wordpress.org redesign of their plugin directory.
- Update to code that suppresses new user registration notification email. WordPress core made a change to the API starting with version 4.3.0 of WordPress, so this update to User Spam Remover fixes the problem where the user gets a bogus registration notification email and is unable to complete site registration. Props to Oliver @ www.webmandesign.eu for the report.
Now requires mysqli. If your PHP version is < 5.5 you may need to force WordPress to use
mysqliinstead of the older
mysqlextension. Just add this line to
wp-config.php, near the top by the other DB settings:
- Now detects and adds absent MySQL indexes to wp_comments.user_id and wp_links.link_owner columns. Greatly speeds performance and enables use on much larger databases. Big props to Raph Koster for help debugging!
- Enables MySQL sql_big_selects config var at runtime for use on shared hosts and other installations where this is disabled by default.
- MySQL SELECT errors now logged/shown to the user as appropriate.
- Hard limit of 1000 users per deletion to prevent long-running operations. Upped limit to 10000 records per SELECT, thanks to improved SQL and indexes.
- No longer deletes users with only comments marked as “spam.” This is a small functional regression, but it speeds SQL performance. Once the spam is permanently removed these users will be deleted anyway.
- Minor bug fix affecting settings page user list display w/ bbPress users.
- Changes to method visibility. Many previously public methods now protected.
- Code refactoring.
- Version/compatibility bump so that wordpress.org plugin repository info is accurate.
- Added check for wp_usermeta ‘last_posted’ record so that users of database-integrated bbPress installations are not deleted if they have ever posted anything.
- Added hard limit of 5000 records to prevent long-running operations.
- Added a list of user accounts pending deletion to the settings page.
- Style fix to inline error messages per r16205 changes to WordPress core file wp-admin/css/colors-fresh.dev.css.
- Miscellaneous minor style fixes.
- Added standard WordPress Users section icon and printing of status message on options update.
- Updated deprecated PHP syntax for string access by character in lcfirst().
- Very minor refactoring and tweak of message text.
- Fixed weird edge case where no usermeta records exist for a given user.
Before: this caused user removal to abort and an error message to be logged.
Now: any such users are deleted.
- Added nonce checking to “Remove now” button on admin page.
- Slight code refactor to remove buried strings.
- Cosmetic change to log strings so plural “s” not added to singular words.
- Initial public release.
- Tested using WordPress 3.0.1 and PHP 5.2.6 and 5.2.14.