We’ve all had this problem. A group of spammers from mail.ru are registering to your blog, but you want to keep registration open. How do you kill the spammers without bothering your clientele? While you could edit your
functions.php and block the domain, once you get past a few bad eggs, you have to escalate.
Ban Hammer does that for you by preventing unwanted users from registering.
On a single install of WP, instead of using its own database table, Ban Hammer pulls from your list of blacklisted emails from the Comment Blacklist feature, native to WordPress. Since emails never equal IP addresses, it simply skips over and ignores them. On a network instance, there’s a network wide setting for banned emails and domains. This means you only have one place to update and maintain your blacklist. When a blacklisted user attempts to register, they get a customizable message that they cannot register.
For advanced documentation, including how to use on WooCommerce, please visit the Ban Hammer Wiki.
Ban Hammer is a very weird fork of Philippe Paquet’s No Disposable Email plugin. The original plugin was a straight forward .dat file that listed all the bad emails (generally ones like mailinator that are disposable) and while Ban Hammer doesn’t do that, this would not have been possible without that which was done before.
Many thanks are due to WP-Deadbolt, for making me think about SQL and TTC for StopForumSpam integration. MASSIVE credit to Travis Hamera for the StopForumSpam/cURL fix! And then props to Helen Hou-Sandí for not using curl at all. Protip? Use WP_http instead!
Latest version: Download Ban Hammer v2.6 [zip]
After installation, go to Tools > Ban Hammer to customize the error message (and banned emails, but it’s the same list from your comment moderation so…).
After installation, go to Network Admin > Settings > Ban Hammer to customize the error message and banned email list. This will ban users network wide.
Q. If I change the blacklist via Ban Hammer, will it change the Comment Blacklist?
A. On single site installs, yes. They are the exact same list, they use the same fields and they update the same data. The only reason I put it there was I felt having an all-in-one place to get the data would be better.
Q. Does this list the rejected registers?
A. No. Since WordPress doesn’t list rejected comments (your blacklist goes to a blackhole), the rejected users are similarly lost forever.
Q. Where did Stop Forum Spam go?
A. This plugin no longer uses Stop Forum Spam. If you need that feature, please use Stop Spammer Registrations instead. They did it way better.
Q. Does this work on MultiSite?
A. Yes it does, but a little differently If you’re using multisite, instead of pulling from the comment blacklist (which is per site), you have a separate list off Network Admin -> Settings. This is because you only want to have the network admins determining who can register on the network.
Q. Does this work on BuddyPress?
A. Currently yes.
Q. Does this work on WooCommerce?
A. Yes but… You have to make your own hook because WooCommerce doesn’t use the normal registration functions. Don’t panic. I have directions here.
Q. Can I block partials?
A. Yes but not wildcards. If you put in
viagra for example, you will block
email@example.com so please use this carefully. If you put in
cookie then you’ll block
firstname.lastname@example.org and everyone would be sad.
If you want to block everyone from all subdomains (like
email@example.com) then you can block
.example.com and that will block all the subdomains.
Q. Why doesn’t this work AT ALL on my site!?
A. I’m not sure. I’ve gotten a handful of reports from people where it’s not working, and for the life of me, I’m stumped. So far, it looks like Zend and/or eAccelerator aren’t agreeing with this. If it’s failing, please post on the wp.org forums with your server specs (PHP info, server type, etc) and any plugins you’re running.
- February 2017 by Ipstenu
- Allow redirection to custom URLs on failed login.
- Move plugin to Settings API
- Combine options
- Fixed BuddyPress
- Optimized multisite
- Removed check for WP 3.4 (only 4.0 and up get updates anyway)