Django Allauth (4) – Email Verification via Gmail
data:image/s3,"s3://crabby-images/60b0c/60b0cc35086772de90525bc7cdf5b779c5755eb6" alt="Configuring Email Verification via Gmail with Django Allauth"
This lesson will explain how to set up email verification via Gmail. The approach can change depending on Google's security policy. This approach is valid as of April 2023.
1. Set up a Gmail App password
You need to set up a Gmail App password to send email verification emails via Gmail. Go to your Gmail account in your browser and click on "Manage your Google Account".
data:image/s3,"s3://crabby-images/094c7/094c772169f899acae6dd7f2c1a4c41d92f09341" alt="Start to set up Gmail App password Start to set up Gmail App password"
Go to 2-Step Verification under the Security section.
data:image/s3,"s3://crabby-images/2192d/2192d43509bc16dbb4f21603cef651dfdc6bd864" alt="Set up Gmail App password: Step 1 Set up Gmail App password: Step 1"
If you haven't set it up yet, follow the guidance to set up 2-Step Verification and turn it on.
data:image/s3,"s3://crabby-images/3ed71/3ed7102df9c2362d795b9361346ba8d187fa42ac" alt="Set up Gmail App password: Step 2 Set up Gmail App password: Step 2"
Go to the App passwords section at the bottom.
data:image/s3,"s3://crabby-images/90393/90393c7a35e9adbc68fa8f8439d992d1e6758843" alt="Set up Gmail App password: Step 3 Set up Gmail App password: Step 3"
Generate an app password with a custom name.
data:image/s3,"s3://crabby-images/fdce3/fdce3b968ac0fe39256cbd94b6627d95dad17392" alt="Set up Gmail App password: Step 4 Set up Gmail App password: Step 4"
You'll see that an app password was generated. Copy the password as we will use it in settings.py.
data:image/s3,"s3://crabby-images/663a4/663a486fe2b647d03e2ef88ab3b65c01147c9865" alt="Set up Gmail App password: Step 5 Set up Gmail App password: Step 5"
2. Edit settings.py
To change the console-based email verification setting to email-based verification, edit settings.py.
- Change
EMAIL_BACKEND
to 'django.core.mail.backends.smtp
.EmailBackend' - Add email settings
The EMAIL_BACKEND
setting enables Django to send emails using the SMTP protocol.
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
EMAIL_HOST = 'smtp.gmail.com'
EMAIL_HOST_USER = 'your_account@gmail.com'
EMAIL_HOST_PASSWORD = 'App Password'
EMAIL_USE_SSL = True
EMAIL_USE_TLS = False
EMAIL_PORT = 465
DEFAULT_FROM_EMAIL = 'your_account@gmail.com'
Make sure that only one of TLS
or SSL
can be True
, and that the port setting is aligned with the protocol. In this case, we use EMAIL_USE_SSL = True
, EMAIL_USE_TLS = False
, and EMAIL_PORT = 465
.
3. Check the results
To check the results, try to sign up again. This time, you need to use an actual email address.
data:image/s3,"s3://crabby-images/68a11/68a115b9c30cc20700caf855e53c0057db4eb844" alt="Django Allauth Sign Up Page UI Django Allauth Sign Up Page UI"
Once you click on the Sign Up button, you'll see a message saying that a verification email has been sent out.
data:image/s3,"s3://crabby-images/5e69d/5e69d12ad6c08f3d7bc7da097ae119a1de3c94e1" alt="Django Allauth email verification message Django Allauth email verification message"
Check your email. You'll see the verification email in your inbox.
data:image/s3,"s3://crabby-images/26329/263291039034bb6bf809745ba1cdffb90e6a81bb" alt="Django Allauth verification email example Django Allauth verification email example"
Click the link, and then you'll see a confirmation message. After you press the Confirm button, your account will be created...
data:image/s3,"s3://crabby-images/1275f/1275f22594fde19d945839e06294105548ed93df" alt="Django Allauth email confirmation message Django Allauth email confirmation message"
...and you'll be ready to sign in (log in) to the service.
data:image/s3,"s3://crabby-images/3dbd1/3dbd10910bf874b57fe89934be8234a905ae3452" alt="Django Allauth Sign In Page UI Django Allauth Sign In Page UI"
Sign in with your registered email and password. You'll jump to the home page (You are successfully logged in to the app).
data:image/s3,"s3://crabby-images/dbcac/dbcac7de66fe7c8a4bf514661a5a9a741e97dc67" alt="Index page UI example (After login) Index page UI example (After login)"
Note: Delete Users
When you are working on the email setting, you may want to test functionalities multiple times. However, the app blocks new registrations that use the same email address. Delete the user from the Django admin to test it again with the same email address.
Go to the Users section on the left menu. Select the user to delete, select "Delete selected users" in the dropdown, and press the Go button.
data:image/s3,"s3://crabby-images/7f2ed/7f2ed6ae4c3dfa754310792174f4ca07fa87ebdd" alt="Django Allauth delete users Django Allauth delete users"
Make sure that you delete the user, not just their email address; or else, even though you delete the email address, the user won't be deleted. But once you delete the user, the registered email address will also be deleted.