Django中的用户身份验证示例详解


Posted in Python onAugust 07, 2019

前言

这次开发微信抢票程序中,普通用户的身份是由微信管理的。当用户通过微信公众号(测试号)向后台发消息时,微信会将用户的身份标记为一个unique_id来识别,后端可以由此来判断用户身份。这种认证比较特殊,它不存在登陆、登出的操作。如果是一个普通的web应用,应该有用户的登陆、登出操作,当用户未经授权访问某个URL的时候,后端应该拒绝这次请求,或者是重定向到登陆界面。

在这次作业中,因为需要一个后台管理员来管理各种活动的创建和发布,因此也需要有用户的身份认证操作。这次的后端是Django,试了一下发现Django实现了一套自己的身份验证的API,用起来非常方便。

用户创建与修改

众所周知,Django中存储数据的原型称为Model,User就是Django中用户的Model,不需要程序员在models.py中自己定义。它有username、password、email、first_name、last_name五个属性。在Django中还有一个称为superuser的用户,它其实是User的一个特殊的子类,在本次微信抢票中,后台管理员就是superuser。

普通User的创建是调用User中的create_user进行创建,而superuser的创建不是在代码中,而是输入python manage.py createsuperuser进行创建。

#普通用户的创建
from django.contrib.auth.models import User
user = User.objects.create_user('john', 'lennon@thebeatles.com', 'johnpassword')
user.last_name = 'Lennon'
user.save()

用户登陆登出

在登陆时,使用authenticate的函数对用户进行验证,如果用户名、密码错误,该函数的返回值为None。此时嗲用login函数将request与该user绑定起来。login的结果是,以后每次的request,在request.user中总会存在用户的信息,这是下一步我们进行权限认证的前提。用户的退出就是调用logout(request)函数即可。

用户权限

request.user.is_authenticated()

一般的情况下(比如在本次微信抢票中),只需要有两种访问可能。一个是用户已登陆,可以访问,一个是用户未登陆,禁止访问。因此我们用这个函数就足够了。(我们确实是这么用的2333)

当然还有一种更简单的用法——函数的装饰器,因为我们用的是类做相应,因此不适合微信抢票程序,但是还是mark一下,因为确实太方便了。就是在函数的前面加上login_required()装饰器,括号中可以填入如果未登陆应该重定向到哪个页面。

但是在其它web应用中,我们需要不同的用户组有不同的权限,这个时候Django提供了另外一个叫做permission的属性。

首先,每个用户都有一个group外键,可以给用户分配在某些group中,然后可以通过group.permissions来修改group的permission列表。

在使用permission的时候,同样可以使用装饰器require_permission。

除此之外,还有一个值得提的地方:装饰器user_passes_test(xxtest),可以自己编写一个test函数来测试用户是否可以访问,test函数接收的参数为request.user

from django.contrib.auth.decorators import user_passes_test
​
def email_check(user):
  return user.email.endswith('@example.com')
​
@user_passes_test(email_check)
def my_view(request):
  ...

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python科学画图代码分享
Nov 29 Python
Python数据拟合与广义线性回归算法学习
Dec 22 Python
对pandas将dataframe中某列按照条件赋值的实例讲解
Nov 29 Python
python运行时强制刷新缓冲区的方法
Jan 14 Python
django admin.py 外键,反向查询的实例
Jul 26 Python
Python实现多线程/多进程的TCP服务器
Sep 03 Python
python 字典的打印实现
Sep 26 Python
解决Python中回文数和质数的问题
Nov 24 Python
Python爬虫:Request Payload和Form Data的简单区别说明
Apr 30 Python
Anaconda+spyder+pycharm的pytorch配置详解(GPU)
Oct 18 Python
python实现马丁策略的实例详解
Jan 15 Python
Python 中的函数装饰器和闭包详解
Feb 06 Python
浅谈Python中(&,|)和(and,or)之间的区别
Aug 07 #Python
Python操作远程服务器 paramiko模块详细介绍
Aug 07 #Python
使用Python快乐学数学Github万星神器Manim简介
Aug 07 #Python
python中的&&及||的实现示例
Aug 07 #Python
程序员的七夕用30行代码让Python化身表白神器
Aug 07 #Python
python代码实现逻辑回归logistic原理
Aug 07 #Python
Python在cmd上打印彩色文字实现过程详解
Aug 07 #Python
You might like
实现dedecms全站URL静态化改造的代码
2007/03/29 PHP
PHP 引用是个坏习惯
2010/03/12 PHP
dhtmlxTree目录树增加右键菜单以及拖拽排序的实现方法
2013/04/26 PHP
php实现查询百度google收录情况(示例代码)
2013/08/02 PHP
php通过curl添加cookie伪造登陆抓取数据的方法
2016/04/02 PHP
浅谈PHP eval()函数定义和用法
2016/06/21 PHP
Yii中的relations数据关联查询及统计功能用法详解
2016/07/14 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
2017/03/16 PHP
PHP设计模式之工厂模式定义与用法详解
2018/04/03 PHP
PHP5.5基于mysqli连接MySQL数据库和读取数据操作实例详解
2019/02/16 PHP
让whoops帮我们告别ThinkPHP6的异常页面
2020/03/02 PHP
详解Vue2.x-directive的学习笔记
2017/07/17 Javascript
JavaScript仿微信(电话)联系人列表滑动字母索引实例讲解(推荐)
2017/08/16 Javascript
React.js绑定this的5种方法(小结)
2018/06/05 Javascript
微信小程序实现简易table表格
2020/06/19 Javascript
微信小程序实现多个按钮的颜色状态转换
2019/02/15 Javascript
微信小程序登录session的使用
2019/03/17 Javascript
使用vue打包进行云服务器上传的问题
2020/03/02 Javascript
Vue + element 实现多选框组并保存已选id集合的示例代码
2020/06/03 Javascript
在vue中使用回调函数,this调用无效的解决
2020/08/11 Javascript
python开发之IDEL(Python GUI)的使用方法图文详解
2015/11/12 Python
python3+selenium自动化测试框架详解
2019/03/17 Python
Django模型序列化返回自然主键值示例代码
2019/06/12 Python
利用CSS3实现自定义滚动条代码分享
2016/08/18 HTML / CSS
使用CSS3代码绘制可爱的Hello Kitty猫
2016/08/03 HTML / CSS
让IE下支持Html5的placeholder属性的插件
2014/09/02 HTML / CSS
罗德与泰勒百货官网:Lord & Taylor
2016/08/12 全球购物
MCM英国官网:奢侈皮具制品
2017/04/18 全球购物
什么是Remote Module
2016/06/10 面试题
中软国际Java程序员笔试题
2014/07/19 面试题
村委会主任先进事迹
2014/01/15 职场文书
环保标语大全
2014/06/12 职场文书
电子工程求职信
2014/07/17 职场文书
2015年安全生产目标责任书
2015/01/29 职场文书
嘉宾邀请函
2015/01/31 职场文书
个人简历求职信范文
2015/03/20 职场文书