描述
Most email validators look for an @
and a .
(dot) some go further and blacklist certain domain names. But Mailgun’s Advanced email validation service goes deeper and looks for the existence of the domain name, presence of a MX record and the custom ESP(Email Service Provider) grammar.
The grammar here is the rules defined by each email provider. For example, Yahoo Mail addresses can only contain letters, numbers, underscores, and one period.
So user.name.abc@yahoo.com
perfectly passes the is_email() function but can never exist as it contains more than one period. Such addresses can’t escape Mailgun’s Email validation.
Why use Mailgun’s email validation service?
- Performs the usual email syntax check.
- Checks the existence of the email domain. So
user@some-random-characters.com
can’t escape. - Checks if the email domain has a MX record. So
anything@example.com
is caught. - Checks if the username complies with the grammar of its ESP (Email Service provider). Eg Gmail doesn’t allow usernames less than 6 characters and hyphens so
small@gmail.com
andhyphen-user@gmail.com
can’t get away.
Why use this plugin?
- Integrates with the is_email() function of WordPress. So it works seamlessly with Contact Form 7, Jetpack/Grunion contact forms, WordPress registration form and any form which uses the
is_email()
function. - Kicks spam before it is inserted into the database
- Ensures that the commenting process is uninterrupted even if Mailgun suffers a downtime
- Works completely transparent, nothing changes in the frontend
This plugin requires a Mailgun Public API Key which can be obtained by signing up at Mailgun.
If you’re trying out this plugin on a local WAMP/LAMP/MAMP installation make sure your system is connected to the Internet for this plugin to contact Mailgun.
Available Languages
- 英文
- Serbo-Croatian by Borisa Djuraskovic
- Spanish by Andrew Kurtis
Further Reading
Read about Mailgun’s email validation service.
屏幕截图
安装
- Unzip and upload the
mailgun-email-validator
folder to the/wp-content/plugins/
directory. - Activate the Mailgun Email Validator plugin through the ‘Plugins’ menu in WordPress.
- Configure the plugin by going to
General > Email Validation
page. - Signup for a Mailgun account (First 100 validations are free every month).
- Login, copy and paste your public API key to
General > Email Validation
page.
常见问题
- Installation Instructions
-
- Unzip and upload the
mailgun-email-validator
folder to the/wp-content/plugins/
directory. - Activate the Mailgun Email Validator plugin through the ‘Plugins’ menu in WordPress.
- Configure the plugin by going to
General > Email Validation
page. - Signup for a Mailgun account (First 100 validations are free every month).
- Login, copy and paste your public API key to
General > Email Validation
page.
- Unzip and upload the
- Why did you create this plugin?
-
I hate comment spam because it bloats my database. I also don’t like bugging my visitors with CAPTCHAs in the form of scribbled text,
counting the puppies and answering questions like What is 3 + 2?
So when Mailgun released their email validation service I tried validating the email addresses of comments in the spam queue of my blog.
I found that nearly 50% of these email addresses were identified incorrect by Mailgun.
Thus this plugin was born. Though not as effective as CAPTCHAs this plugin can prevent a decent amount of spam while maintaining user experience. - Is this plugin a product of Mailgun?
-
No. It only makes use of Mailgun’s email validation service API. Nothing in the code belongs to Mailgun.
- I get a *401 Unauthorized* error when I verify the API key but I’m very sure that it is correct
-
You could be using the normal API key, for this plugin you need to enter the Public API Key this is slightly
longer than the normal API key and is found just below it. - This plugin is active and I have entered a Valid Public API Key but it doesn’t work
-
Try the email validation demo from the plugin’s option page. It could a connectivity issue.
- What happens if Mailgun’s service is down?
-
In such cases emails are passed on untouched (as though this plugin is nonexistent) and on the front-end users won’t notice anything.
- What contact form plugins are supported?
-
Any form which uses the
is_email()
function are supported this means the most popular ones like Contact Form 7, Jetpack by WordPress.com, Grunion Contact Form
and a lot of others are supported. - Does Mailgun support this plugin?
-
No, because Mailgun didn’t create it. If you need support create a thread
by choosing the Support tab of this plugin. If you directly create a thread in the forum I’ll never know of its existence. - I want to see a demo of emails validating
-
Mailgun has created a jquery demo at this page. The code for this demo is available here.
评价
贡献者及开发者
更新日志
1.2.4.1
- 19th October 2017
- Add global variables $pagenow and $wp
1.2.4
- 8th October 2017
- Don’t use Mailgun validation on the WooCommerce WP-Admin orders page. More details…
1.2.3
- 16th October 2016
- Removed PHP4 style constructors for PHP 7 compatibility
1.2.2
- 21st April 2015
- Use Mailgun’s API v3
- Added Spanish language, props Andrew Kurtis
1.2.1
- 19th October 2014
- Use HTTP HEAD instead of GET to validate API key. More details…
1.2
- 3rd September 2014
- Added Serbo-Croatian language, props Borisa Djuraskovic
1.1
- 3rd November 2013
- Plugin is translation ready
1.0
- 5th October 2013
- Initial version