django-allauth 教程(一)小试牛刀

会飞的鱼
• 阅读 1256
前言:最近需要做毕业设计,搞一个基于Django的武汉选房网站,有点类似于安居客,链家之类,但是由于技术有限,搞不来大型网站。我第一次写博客,希望屏幕前的大佬多多指教!!

首先学习django-allauth, django-allauth是最受欢迎管理用户登录和注册的第三方安装包,GitHub地址:https://github.com/pennersr/django-allauth

1.创建一个Django项目:

django-allauth 教程(一)小试牛刀 新建一个数据库House_website_db,在setting.py输入

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # 用的是Mysql数据库
        'NAME': 'House_website_db',
        'USER': '用户',
        'PASSWORD': '密码噻',
        'HOST': '127.0.0.1',
    }
}

2.django-allauth安装

在terminal中输入

pip install django-allauth

安装好后在House_website/setting.py中,将allauth相关的APP加入到INSTALLED_APPS列表中,需要注意的是allauth对站点设置django.contrib.sites有依赖,必须也把它加入,同时设置SITE_ID=1,

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'django.contrib.sites',
    'allauth',
    'allauth.account',
    'allauth.socialaccount',
    'allauth.socialaccount.providers.github',
]
SITE_ID = 1

网站需要用户通过email或者用户名进行登录,因为我们需要进行邮箱验证和通过邮箱发送密码重置链接,所以很有必要设置电子邮箱。如果你没有邮件服务器,你可以设置成自己的QQ邮箱或者163邮箱,本地环境下一样可以使用,是不是很棒,我第一次做出来时就觉得diao。接下来我说说localhost环境下怎么配置QQ邮箱或163邮箱发送文件。 首先在setting.py文件中输入

# 基本设定
ACCOUNT_AUTHENTICATION_METHOD = 'username_email'
ACCOUNT_EMAIL_REQUIRED = True
LOGIN_REDIRECT_URL = '/accounts/profile/'
ACCOUNT_LOGOUT_REDIRECT_URL = "/accounts/login"  # 设置退出登录后跳转链接
ACCOUNT_LOGIN_ON_EMAIL_CONFIRMATION = True  # 更改为True,用户一旦确认他们的电子邮件地址,就会自动登录
ACCOUNT_LOGIN_ON_PASSWORD_RESET = True  # 更改为True,用户将在重置密码后自动登录
ACCOUNT_USERNAME_BLACKLIST = []  # 用户不能使用的用户名列表

AUTHENTICATION_BACKENDS = (
    'django.contrib.auth.backends.ModelBackend',
    'allauth.account.auth_backends.AuthenticationBackend',
)

# 邮箱设定
EMAIL_HOST = 'smtp.163.com' # 如果你用的是QQ邮箱,就改成'smtp.qq.com'
EMAIL_PORT = 25
EMAIL_HOST_USER = 'xxxxx@163.com'  # 你的 qq邮箱或者163邮箱
EMAIL_HOST_PASSWORD = 'xxxxxxxxxxxxx' # 你的授权码
EMAIL_USE_TLS = True  # 这里必须是 True,否则发送不成功
EMAIL_FROM = 'xxxxx@163.com'  # 你的 qq邮箱或者163邮箱
DEFAULT_FROM_EMAIL = 'xxxx@163.com'  # 你的 qq邮箱或者163邮箱

当然基本设定还有好多:括号里的是默认设置

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 (="/") # 设置退出登录后跳转链接

3.接下来就是拿到授权码了

QQ邮箱授权码:

进入QQ邮箱网页,找到设置

django-allauth 教程(一)小试牛刀

django-allauth 教程(一)小试牛刀

django-allauth 教程(一)小试牛刀

163邮箱授权码:

进入网址:https://mail.163.com/ 找到设置, django-allauth 教程(一)小试牛刀 开启服务, django-allauth 教程(一)小试牛刀 拿到授权码 之后将授权码写进setting.py里面。

4.查看效果

在House_website/urls.py配置url:

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('accounts/', include('allauth.urls')),
]

在Terminal输入以下命令:

python manage.py makemigrations  # 生成映射文件
# 这里会提示你需要安装mysqlclient库
pip install mysqlclient
python manage.py migrate  # 执行映射文件,创建数据表
python manage.py runserver   # 运行服务

django-allauth的URLs及视图

下面是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? 如果我希望用户能提供更多信息怎么办?比如电话,QQ,年龄,性别,个性签名等等。那如果希望用户登陆后跳转到个人信息页面(UserProfile),并允许用户修改个人信息怎么搞?因为每个开发者都有不同的需求,这就需要我们自己写了,django-allauth就没提供。

特别鸣谢:大江狗前辈 声明:我写博客只是记录自己的学习进度和总结并分享给大家,并不保证原创,如有引用您的博文,请您理解!

点赞
收藏
评论区
推荐文章
浅梦一笑 浅梦一笑
4个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
1年前
Java爬虫之JSoup使用教程
title:Java爬虫之JSoup使用教程date:201812248:00:000800update:201812248:00:000800author:mecover:https://imgblog.csdnimg.cn/20181224144920712(https://www.oschin
Wesley13 Wesley13
1年前
4cast
4castpackageloadcsv.KumarAwanish发布:2020122117:43:04.501348作者:KumarAwanish作者邮箱:awanish00@gmail.com首页:
Wesley13 Wesley13
1年前
Java日期时间API系列36
  十二时辰,古代劳动人民把一昼夜划分成十二个时段,每一个时段叫一个时辰。二十四小时和十二时辰对照表:时辰时间24时制子时深夜11:00凌晨01:0023:0001:00丑时上午01:00上午03:0001:0003:00寅时上午03:00上午0
Wesley13 Wesley13
1年前
MySQL查询按照指定规则排序
1.按照指定(单个)字段排序selectfromtable_nameorderiddesc;2.按照指定(多个)字段排序selectfromtable_nameorderiddesc,statusdesc;3.按照指定字段和规则排序selec
Stella981 Stella981
1年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Stella981 Stella981
1年前
Angular material mat
IconIconNamematiconcode_add\_comment_addcommenticon<maticonadd\_comment</maticon_attach\_file_attachfileicon<maticonattach\_file</maticon_attach\
Wesley13 Wesley13
1年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
helloworld_34035044 helloworld_34035044
6个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
会飞的鱼
会飞的鱼
Lv1
多情自古空余恨,好梦由来最易醒。
2
文章
0
粉丝
0
获赞