Gmail SMTP plugin allows you to authenticate with your Gmail account to send email via Gmail SMTP server.
Most shared hosting servers have restrictions when it comes to email. Usually email will get blocked or missing for no reason. Sometimes it will get blocked when your website reaches the daily limit of outgoing email. This plugin can bypass this issue by routing the email through Gmail’s SMTP server.
Gmail SMTP Benefits
- Gmail SMTP plugin is not like most SMTP plugins. It uses the OAuth 2.0 protocol to authorize access to the Gmail API – which means a more secure login system and users won’t have to enter any username or password.
- Gmail SMTP plugin uses PHPMailer – a very popular library used for sending email through PHP’s mail function. This libary is also used in the core WordPress to send email.
- Gmail SMTP plugin utilizes “wp_mail” (A function used by WordPress to send email) instead of completely overriding it. This way you still get all the benefits of the default mail function.
- You no longer need to enable Allow less secure apps on your gmail account to fix SMTP connection issue. This issue became prominent from December 2014, when Google started imposing XOAUTH2 authentication (based on OAuth2) to access their apps. This issue still affects almost all the SMTP plugins because they authenticate via username and password.
How OAuth 2.0 Authorization Works
- You register an application in the Google Developers Console.
- The application is launched and it requests that you give it access to data in your Google account.
- If you consent, the application receives credentials to access the Gmail API.
Gmail SMTP Features
- Configure your website to send email using Gmail SMTP server
- Authenticate using OAuth 2.0 protocol
- Authenticate with encryption when sending an email (TLS/SSL)
Gmail SMTP Basic Setup
- Go to the plugin settings (
- Create a new web application using the link.
- Set the Authorized Redirect URL of the application as the one shown in the settings.
- Copy the Client ID and Client secret and paste into the settings area.
- Enter your OAuth Email, From Email and From name.
- Select an encryption.
- Enter a port number.
- Save the settings.
- Now you can authorize your application to access the Gmail API by clicking on the Grant Permission button.
- Once the application has been authorized Gmail SMTP plugin will be able to take control of all outgoing email.
Gmail SMTP Settings
- Authorized Redirect URI: Authorized redirect URL for your website. You need to copy this URL into your web application.
- Client ID: The client ID of your web application.
- Client secret: The client secret of your web application.
- OAuth Email Address: The email address that you will use for SMTP authentication. This should be the same email used in the Google Developers Console.
- From Email Address: The email address which will be used as the From Address when sending an email.
- From Name: The name which will be used as the From Name when sending an email.
- Type of Encryption: The encryption which will be used when sending an email (TLS/SSL. TLS is recommended).
- SMTP Port: The port which will be used when sending an email. If you choose TLS it should be set to 587. For SSL use port 465 instead.
- Disable SSL Certificate Verification: As of PHP 5.6 a warning/error will be displayed if the SSL certificate on the server is not properly configured. You can check this option to disable that default behaviour.
Gmail SMTP Test Email
Once you have configured the settings you can send a test email to check the functionality of the plugin.
- To: Email address of the recipient.
- Subject: Subject of the email.
- Message: Email body.
For detailed setup instructions please visit the Gmail SMTP plugin page.
- PHP 5.4 or later
- A Gmail Account
- A self-hosted WordPress site
- Go to the Add New plugins screen in your WordPress Dashboard
- Click the upload tab
- Browse for the plugin file (gmail-smtp.zip) on your computer
- Click “Install Now” and then hit the activate button
- Can I send email from my Gmail account using this plugin?
- Can this plugin use OAuth 2.0 to send email?
I’ve had a very easy experience setting up Gmail SMTP. Highly recommended.
>>> HOWEVER, if you use GoDaddy hosting, it will NOT work for you. This is due to GoDaddy’s restrictions on port 587, and is not the fault of Gmail SMTP.
Highly recommended – great job, guys!
This plugin solved the EXACT issue I was having, trying to send outgoing email from my WP install using Gmail. I highly recommend it!
(The instructions page could use a refresh — they’re a little outdated but still usable)
No web developer wants “that call” from their client saying they are not getting emails sent from their website. Plus, a lot of my client’s don’t want to create an email address for their domain name. Instead, they want to continue using their gmail email as they have always done.
This plugin gets the job done! I have walked two clients through the process of configuring the plugin over the phone. Neither client is particularly great at using a computer, but they were both able to do it. So, with a bit of patience, anyone can setup this plugin.
Basically, I am a fan. Bravo!
Fatal error message, not working
This plugin looked like it was able to do what I wanted (send as a group email address ‘no-reply’ rather than my user email address in Google’s G Suite), which would have been awesome and I would have 5 star’d this plugin in an instant. BUT, it requires the PHP ‘allow_url_fopen’ runtime which I have specifically disabled on my server because it is a security risk.
Postman SMTP plugin can do OAuth with Google without the ‘allow_url_fopen’ runtime, but doesn’t seem to allow for sending email as a google group like this plugin seemed to do.
Contributors & Developers
“Gmail SMTP” is open source software. The following people have contributed to this plugin.Contributors
- Updated the PHPMailer library to version 5.2.22. This release contains a critical security fix for CVE-2017-5223.
- Updated the PHPMailer library to version 5.2.21. This release contains a critical security update for CVE-2016-10045 that was fixed in PHPMailer 5.2.20.
- Updated the PHPMailer library to the latest version (5.2.19). This release also contains a critical security update for CVE-2016-10033 that was fixed in PHPMailer 5.2.18.
- Gmail SMTP now supports the “wp_mail_failed” hook which fires after a phpmailerException is caught.
- Added more requirements to the Server Info tab to help with troubleshooting.
- Compatible with WooCommerce email in HTML format.
- Added a new option to bypass this error on some servers where the SSL certificate is not properly configured – Warning: stream_socket_enable_crypto(): SSL operation failed with code 1.
OpenSSL Error messages: error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
- Fixed a bug that was causing this error – “Strict Standards: Non-static method GmailXOAuth2::getClient()”
- google-api-php-client’s autoloader path now points to the src directory as the current autoloader has been deprecated
- Gmail SMTP plugin is now compatible with WordPress 4.4
- Added a new tab to show some server related information
- More debug data will be shown when sending a test email
- Fixed a bug where the oauth URL was pointing to localhost
- First commit