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的Bottle框架中实现最基本的get和post的方法的教程
Apr 30 Python
Python处理文本文件中控制字符的方法
Feb 07 Python
Python的装饰器使用详解
Jun 26 Python
python中判断文件编码的chardet(实例讲解)
Dec 21 Python
Python格式化日期时间操作示例
Jun 28 Python
python 计算数据偏差和峰度的方法
Jun 29 Python
一文了解python 3 字符串格式化 F-string 用法
Mar 04 Python
使用Jupyter notebooks上传文件夹或大量数据到服务器
Apr 14 Python
python IDLE添加行号显示教程
Apr 25 Python
Python就将所有的英文单词首字母变成大写
Feb 12 Python
Python3+PyCharm+Django+Django REST framework配置与简单开发教程
Feb 16 Python
python反编译教程之2048小游戏实例
Mar 03 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
动态新闻发布的实现及其技巧
2006/10/09 PHP
不错的PHP学习之php4与php5之间会穿梭一点点感悟
2007/05/03 PHP
ThinkPHP中__initialize()和类的构造函数__construct()用法分析
2014/11/29 PHP
PHP验证信用卡卡号是否正确函数
2015/05/27 PHP
PHP实现上传图片到数据库并显示输出的方法
2018/05/31 PHP
JavaScript 拖拉缩放效果
2008/12/10 Javascript
JS去除字符串的空格增强版(可以去除中间的空格)
2009/08/26 Javascript
jQuery function的正确书写方法
2013/08/02 Javascript
如何让DIV可编辑、可拖动示例代码
2013/09/18 Javascript
javascript最基本的函数汇总
2015/06/25 Javascript
AngularJS 服务详细讲解及示例代码
2016/08/17 Javascript
详解AngularJS ui-sref的简单使用
2017/04/24 Javascript
vue中路由参数传递可能会遇到的坑
2017/12/07 Javascript
vue解决使用webpack打包后keep-alive不生效的方法
2018/09/01 Javascript
ionic使用angularjs表单验证(模板验证)
2018/12/12 Javascript
微信小程序引入Vant组件库过程解析
2019/08/06 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
2019/09/01 Javascript
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
2020/04/24 Javascript
为react组件库添加typescript类型提示的方法
2020/06/15 Javascript
python在命令行下使用google翻译(带语音)
2014/01/16 Python
Python打包文件夹的方法小结(zip,tar,tar.gz等)
2016/09/18 Python
详解Python的Lambda函数与排序
2016/10/25 Python
python使用Pandas库提升项目的运行速度过程详解
2019/07/12 Python
python读取大文件越来越慢的原因与解决
2019/08/08 Python
Python定义函数实现累计求和操作
2020/05/03 Python
python利用opencv实现颜色检测
2021/02/23 Python
CSS3属性box-sizing使用指南
2014/12/09 HTML / CSS
高中竞选班长演讲稿
2014/04/24 职场文书
公司法定代表人授权委托书
2014/09/29 职场文书
党员查摆四风问题思想汇报
2014/10/25 职场文书
2014年党风建设工作总结
2014/11/19 职场文书
2014年食品安全工作总结
2014/12/04 职场文书
考试作弊检讨书范文
2015/01/27 职场文书
长城英文导游词
2015/01/30 职场文书
Java基础之this关键字的使用
2021/06/30 Java/Android
nginx之queue的具体使用
2022/06/28 Servers