前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Django | allauth】登录_注册_邮箱验证_密码邮箱重置

【Django | allauth】登录_注册_邮箱验证_密码邮箱重置

原创
作者头像
计算机魔术师
发布2022-08-16 14:38:49
3.8K0
发布2022-08-16 14:38:49
举报
文章被收录于专栏:计算机魔术师
在这里插入图片描述
在这里插入图片描述

🤵‍♂️ 个人主页: @计算机魔术师

👨‍💻 作者简介:CSDN内容合伙人,全栈领域优质创作者。

**该文章收录专栏**

---【Django | 项目开发】从入门到上线 专栏---

@TOC

一、安装与配置

  • 安装allauth包,
代码语言:shell
复制
pip install allauth

我们假设你已经创建好了项目 allauthDemo

  • 在setting中引入应用,**由于allauth对站点django.contrib.sites有依赖,所以需要加上该应用,并配置站点**
代码语言:python
代码运行次数:0
复制
...

 # allauth

    'django.contrib.sites',  # first place

    'allauth',

    'allauth.account',

    'allauth.socialaccount',

]

SITE\_ID = 1
  • setting对allauth基本配置
代码语言:python
代码运行次数:0
复制
# allauth 基本设定

ACCOUNT\_AUTHENTICATION\_METHOD = 'username\_email' # 设置用户名和邮箱登录

ACCOUNT\_EMAIL\_REQUIRED = True # 注册需要填写邮箱

ACCOUNT\_REDIRECT\_URL = '/accounts/profile/' # 登录跳转页面

AUTHENTICATION\_BACKENDS = [

    'django.contrib.auth.backends.ModelBackend',

    'allauth.account.auth\_backends.AuthenticationBackend'

]

allauth- configuration配置官方文档

常用配置:

代码语言:c++
复制
ACCOUNT\_AUTHENTICATION\_METHOD (="username" | "email" | "username\_email"):指定要使用的登录方法(用户名、电子邮件地址或两者之一)



ACCOUNT\_EMAIL\_CONFIRMATION\_EXPIRE\_DAYS (=3):邮件确认邮件的截止日期(天数)



ACCOUNT\_EMAIL\_VERIFICATION (="optional"):注册中邮件验证方法:“强制(mandatory)”,“可选(optional)”或“否(none)”之一



ACCOUNT\_EMAIL\_CONFIRMATION\_COOLDOWN (=180):邮件发送后的冷却时间(以秒为单位)



ACCOUNT\_LOGIN\_ATTEMPTS\_LIMIT (=5):登录尝试失败的次数



ACCOUNT\_LOGIN\_ATTEMPTS\_TIMEOUT (=300):从上次失败的登录尝试,用户被禁止尝试登录的持续时间



ACCOUNT\_LOGIN\_ON\_EMAIL\_CONFIRMATION (=False):更改为True,用户一旦确认他们的电子邮件地址,就会自动登录



ACCOUNT\_LOGOUT\_ON\_PASSWORD\_CHANGE (=False):更改或设置密码后是否自动退出



ACCOUNT\_LOGIN\_ON\_PASSWORD\_RESET (=False):更改为True,用户将在重置密码后自动登录



ACCOUNT\_SESSION\_REMEMBER (=None):控制会话的生命周期,可选项还有:False,True



ACCOUNT\_SIGNUP\_EMAIL\_ENTER\_TWICE (=False):用户注册时是否需要输入邮箱两遍



ACCOUNT\_SIGNUP\_PASSWORD\_ENTER\_TWICE (=True): 用户注册时是否需要用户输入两遍密码



ACCOUNT\_USERNAME\_BLACKLIST (=[]):用户不能使用的用户名列表



ACCOUNT\_UNIQUE\_EMAIL (=True): 加强电子邮件地址的唯一性



ACCOUNT\_USERNAME\_MIN\_LENGTH (=1):用户名允许的最小长度的整数



SOCIALACCOUNT\_AUTO\_SIGNUP (=True):使用从社会帐户提供者检索的字段(如用户名、邮件)来绕过注册表单



LOGIN\_REDIRECT\_URL (="/") 设置登录后跳转链接



ACCOUNT\_LOGOUT\_REDIRECT\_URL (="/") 设置退出登录后跳转链接

二、邮箱配置

  • 配置邮箱(这里配置已qq为例)
代码语言:python
代码运行次数:0
复制
EMAIL\_HOST: 'smtp.qq.com' # 邮件服务器地址

EMAIL\_POST: 25 #端口号

ENAIL\_HOST\_USER =  '\*\*\*' #QQ账号

EMAIL\_HOST\_PASSWORD = '\*\*\*\*\*'  # 授权码或密码(qq是授权码)

EMAIL\_USE\_TLS = True  # 默认

DEFAULT\_FROM\_EMAIL = EMAIL\_HOST\_USER  # 配置默认发信人

如果不想要邮箱验证可添加配置如下

代码语言:python
代码运行次数:0
复制
ACCOUNT\_EMAIL\_VERIFICATION (="nonel") # 不发送邮箱
  • 在项目的url文件引入allauthurl.py
代码语言:c++
复制
urlpatterns = [

    path('admin/', admin.site.urls),

    path('accounts/', include('allauth.urls'))

]

三、启动服务器运行

  • 三板斧启动服务器(现使用sqlite 数据库,后面再迁移至mysql)
代码语言:shell
复制
python manage.py makmigrations

python manage.py migrate

python manage.py runserve
  • 由于配置好了邮箱,所以**注册邮箱验证以及重置密码部分**都是可已正常运行的(**有一点注意**: 注册好之后,不需要邮箱验证,数据库也会将用户信息存入,邮箱验证只是需要确定邮箱是否正确,不需要验证后才注册成功,这是因为 ACCOUNT\_EMAIL\_VERIFICATION (="optonal") 为默认值为可选,如果需要验证才能注册可修改为 mandatory

以下网页都可以正常访问

代码语言:c++
复制
http://127.0.0.1:8000/accounts/signup/



http://127.0.0.1:8000/accounts/login/



http://127.0.0.1:8000/accounts/logout/



http://127.0.0.1:8000/accounts/password/reset/

四、运行服务器效果

signup 注册页面

在这里插入图片描述
在这里插入图片描述

login 页面

在这里插入图片描述
在这里插入图片描述

password/reset 页面

在这里插入图片描述
在这里插入图片描述

email 页面

在这里插入图片描述
在这里插入图片描述

logout页面

在这里插入图片描述
在这里插入图片描述

邮箱重置密码

在这里插入图片描述
在这里插入图片描述

注册绑定邮箱验证

在这里插入图片描述
在这里插入图片描述

confirm-email 页面

在这里插入图片描述
在这里插入图片描述

如果觉得邮箱提示地址 example.com 名字太丑,还可以在admin 中修改 display\_name

在这里插入图片描述
在这里插入图片描述
  • 下面是django_allauth所有内置的URLs,均可以访问的。

/accounts/login/(URL名account_login): 登录

/accounts/signup/ (URL名account_signup): 注册

/accounts/password/reset/(URL名: account_reset_password) :重置密码

/accounts/logout/ (URL名account_logout): 退出登录

/accounts/password/set/ (URL名:account_set_password): 设置密码

/accounts/password/change/ (URL名: account_change_password): 改变密码(需登录)

/accounts/email/(URL名: account_email) 用户可以添加和移除email,并验证

/accounts/social/connections/(URL名:socialaccount_connections): 管理第三方账户

  • 你有没有注意到没有/accounts/profile/这个URL?如果我们希望用户在注册时提供更多信息怎么办(比如公司名和电话)? 如果我希望用户在登录后跳转到个人信息页面(UserProfile),并允许用户修改个人信息怎么办?因为每个开发者对用户所需提供的额外信息需求都不是一样的,所以django-allauth没有提供这个视图和URL。
在这里插入图片描述
在这里插入图片描述

参考文献:

allauth登录注册与邮箱验证

django发送邮箱

扩展用户自带user模型(非allauth实现)

外键related_name

def _ str_ (self)

def _ str_ (self)

verbose_name

admin自定模型

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、安装与配置
  • 二、邮箱配置
  • 三、启动服务器运行
  • 四、运行服务器效果
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档