Django自带用户认证系统使用方法解析


Posted in Python onNovember 12, 2020

Django自带用户认证系统,这个系统支持访问控制、注册用户、关联创建者和内容等;在开发用户认证功能时的时候,可以使用django中的django.contrib.auth 中封?了注册、认证,登录登出方法,可以直接使用;

相关表

在使用"python manage.py makemigrationss"和"python manage.py migrate"迁移完成数据库之后

根据配置文件settings.py中的数据库段生成的数据表中已经包含了6张进行认证的数据表,分别是

  • auth_user
  • auth_group
  • auth_group_permissions
  • auth_permission
  • auth_user_groups
  • auth_user_user_permissions

自带用户认证系统,进行用户认证的数据表为auth_user(用户的数据保存在这个表里)

一、登陆功能:

authenticate():提供了用户认证,即验证用户名以及密码是否正确,一般需要username和password两个关键字参数

如果通过认证,authenticate()函数会返回一个User对象。当我们试图登陆一个从数据库中直接取出来不经过authenticate()的User对象时会报错。

1.登陆 auth.authenticate(username=name值, password=password值)

2.验证用户名和密码 auth.login(request, user) 这个函数使用Django的session框架给某个已认证的用户附加上session_id信息。

from django.shortcuts import render,redirect,HttpResponse
from django.contrib.auth import authenticate,login
def auth_view(request):
 username=request.POST.GET("usernmae") # 获取用户名
 
password=request.POST.GET("password") # 获取用户的密码
 
user=authenticate(username=username,password=password) # 验证用户名和密码,返回用户对象
 
if user:   # 如果用户对象存在
 

login(request,user)  # 用户登陆
 

return redirect("/index/")
 
else:
 

return HttpResponse("用户名或密码错误")

当用户登陆成功时,会生成一个sessionid保存在cookies中,可以在数据库django_session中查看,当用户访问其他页面时,可以通过sessionid判断用户是否已经登陆。

Django自带用户认证系统使用方法解析

Django自带用户认证系统使用方法解析

二、注册功能

django自带User模型,导入方法:from django.contrib.auth.models import User

User是auth模块中维护用户信息的关系模式,在数据库中被命名为auth_user,使用migrate会自动生成.

user对象

User对象属性:username,password为必填项

password用哈希算法保存到数据库中

  • is_staff:判断用户是否拥有网站的管理权限
  • is_active:判断是否允许用户登陆,设置为“False”时可以不用删除用户来禁止用户登陆

用create_user辅助函数创建用户

a、create_user创建用户

create_user是django封装好的用于创建用户的方法(注意使用该方法注册的用户才能处理密码明文存密文到数据库的问题),

创建方法:User.objects.create_user(username=name, password=password)此处的User是django中自带的User模型from django.contrib.auth.models import User

def regist(request):
name = request.POST.get('name')
password = request.POST.get('password')
User.objects.create_user(username=name, password=password)

三、退出登陆auth.logout(request)

这个函数接受一个HttpResponse对象,无返回值。当调用该函数时,当前请求的session信息全部被清除。即使当前用户没有登陆,调用该函数也不会报错。

def logout(request):
if request.method == 'GET':
auth.logout(request)

四、登陆态验证

login_required() 若在访问某页面时,需要确认用户登陆成功才能访问,可以在url中用login_required方法进行验证,如果登陆成功就执行,如果用户未登陆,自动跳转登陆页面。

a.login_requierd()装饰器

配置跳转路径,,当用户未登陆访问其他页面时,自动跳转到指定的url

url(r'^index/', login_required(views.index)),
url(r'^addstu/', login_required(views.addStu), name='astu'),
url(r'^stupage/', login_required(views.stuPage)),

值得注意的是,一旦加上login_required方法,在用户未登陆时访问页面会出现如下的404错误,所需还需要在setting.py进行配置LOGIN_URL。

user对象的login_requierd()装饰器

Django自带用户认证系统使用方法解析

配置跳转路径,当用户未登陆访问其他页面时,自动跳转到登陆页面

LOGIN_URL = '/login/'

装饰器也可以加到view方法前

from django.contrib.auth.decorators import login_required
@login_required

def views(request):


pass

五、修改存储自定义认证中的User表

用户也可以不使用自带用户认证系统默认的数据表auth_user,通过以下方式可以将用户数据保存到自己定义的表中

from django.contrib.auth.models import User
class UserProfile(models.Model):
  user = models.OneToOneField(User,on_delete=models.CASCADE) # django自带用户表User模块和自定义的用户关联
  name = models.CharField(max_length=32)
  def __str__(self):
    return self.name

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python3基础之函数用法
Aug 13 Python
基于python的Tkinter实现一个简易计算器
Dec 31 Python
Python多线程、异步+多进程爬虫实现代码
Feb 17 Python
Python学习入门之区块链详解
Jul 25 Python
Python Json模块中dumps、loads、dump、load函数介绍
May 15 Python
Python 忽略warning的输出方法
Oct 18 Python
关于python多重赋值的小问题
Apr 17 Python
如何使用python操作vmware
Jul 27 Python
Python随机函数库random的使用方法详解
Aug 21 Python
python实现快递价格查询系统
Mar 03 Python
matplotlib 三维图表绘制方法简介
Sep 20 Python
Pycharm快捷键配置详细整理
Oct 13 Python
Django多数据库联用实现方法解析
Nov 12 #Python
Django数据库迁移常见使用方法
Nov 12 #Python
python爬虫中PhantomJS加载页面的实例方法
Nov 12 #Python
python调用win32接口进行截图的示例
Nov 11 #Python
python 下载m3u8视频的示例代码
Nov 11 #Python
pytorch简介
Nov 11 #Python
Python远程linux执行命令实现
Nov 11 #Python
You might like
浅析Yii中使用RBAC的完全指南(用户角色权限控制)
2013/06/20 PHP
ThinkPHP中Common/common.php文件常用函数功能分析
2016/05/20 PHP
PHP新特性之字节码缓存和内置服务器
2017/08/11 PHP
jQuery 美元符冲突的解决方法
2010/03/28 Javascript
自制轻量级仿jQuery.boxy对话框插件代码
2010/10/26 Javascript
ko knockoutjs动态属性绑定技巧应用
2012/11/14 Javascript
JavaScript中“基本类型”之争小结
2013/01/03 Javascript
jquery 扑捉回车键事件代码
2014/04/24 Javascript
开源的javascript项目Kissy介绍
2014/11/28 Javascript
js使用Array.prototype.sort()对数组对象排序的方法
2015/01/28 Javascript
javascript模拟命名空间
2015/04/17 Javascript
实现一个简单的vue无限加载指令方法
2017/01/10 Javascript
函数四种调用模式以及其中的this指向
2017/01/16 Javascript
Node.js编写CLI的实例详解
2017/05/17 Javascript
浅谈通过JS拦截 pushState和replaceState事件
2017/07/21 Javascript
基于vue.js路由参数的实例讲解——简单易懂
2017/09/07 Javascript
jQuery实现打开网页自动弹出遮罩层或点击弹出遮罩层功能示例
2017/10/19 jQuery
jQuery实现标签子元素的添加和赋值方法
2018/02/24 jQuery
如何用input标签和jquery实现多图片的上传和回显功能
2018/05/16 jQuery
微信小程序开发之路由切换页面重定向问题
2018/09/18 Javascript
Vue框架TypeScript装饰器使用指南小结
2019/02/18 Javascript
浅谈redux, koa, express 中间件实现对比解析
2019/05/23 Javascript
[01:05:32]DOTA2上海特级锦标赛主赛事日 - 3 败者组第三轮#1COL VS Alliance第一局
2016/03/04 DOTA
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
Python Web程序部署到Ubuntu服务器上的方法
2018/02/22 Python
Python Django简单实现session登录注销过程详解
2019/08/06 Python
python 申请内存空间,用于创建多维数组的实例
2019/12/02 Python
python二分法查找算法实现方法【递归与非递归】
2019/12/06 Python
给 TensorFlow 变量进行赋值的方式
2020/02/10 Python
python合并多个excel文件的示例
2020/09/23 Python
HTML5之多线程(Web Worker)
2019/01/02 HTML / CSS
印度尼西亚最好的小工具在线商店:Erafone.com
2019/03/26 全球购物
初中体育教学反思
2014/01/14 职场文书
师德师风自我剖析材料
2014/09/27 职场文书
追悼会答谢词
2015/01/05 职场文书
导游词之澳门玫瑰圣母堂
2019/12/03 职场文书