前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >学习猿地 python教程 django教程10 Django中的用户认证

学习猿地 python教程 django教程10 Django中的用户认证

作者头像
学习猿地
发布2020-03-25 18:04:48
9110
发布2020-03-25 18:04:48
举报
文章被收录于专栏:学习猿地学习猿地

# Django中的用户认证

Django带有一个用户认证系统。它处理用户帐户,组,权限和基于cookie的用户会话。本文档的这一部分解释了默认实现如何开箱即用,以及如何[扩展和定制](https://docs.djangoproject.com/en/1.11/topics/auth/customizing/)它以适应您的项目需求。

[文档地址:https://docs.djangoproject.com/en/1.11/topics/auth/](https://docs.djangoproject.com/en/1.11/topics/auth/)

## 概述

Django认证系统处理认证和授权。简而言之,身份验证验证用户是他们自称的用户,并且授权决定允许经过身份验证的用户执行的操作。这里使用术语认证来指代这两个任务。

认证系统由以下部分组成:

* 用户

* 权限:指定用户是否可以执行特定任务的二进制(是/否)标志。

* 组:将标签和权限应用于多个用户的通用方法。

* 一个可配置的密码散列系统

* 表单和查看工具,用于登录用户或限制内容

* 可插入的后端系统

### 用户,组,认证 模型

[https://docs.djangoproject.com/en/1.11/ref/contrib/auth/](https://docs.djangoproject.com/en/1.11/ref/contrib/auth/)

用户操作

```

创建用户

User.objects.create_user()

# 创建普通用户

myuser = User.objects.create_user(

request.POST['username'],

request.POST['email'],

request.POST['password']

)

创建超级用户

User.objects.create_superuser(用户名,电子邮件,密码,** extra_fields)

# 创建超级用户

myuser = User.objects.create_superuser(

request.POST['username'],

request.POST['email'],

request.POST['password']

)

```

组操作

```

# 创建组

g = Group()

g.name = request.POST['name']

# 执行添加

g.save()

为组分配权限

prms = request.POST.getlist('prms',None)

# 添加权限

if prms:

ps = Permission.objects.filter(id__in=prms)

g.permissions.set(ps)

g.save()

为用户分配组

gs = Group.objects.filter(id__in=request.POST.getlist('groupid',None))

ob.groups.set(gs)

获取组

# 获取所有的组

ob = Group.objects.all()

# 获取当前组信息

ginfo = Group.objects.get(id=gid)

# 获取当前组下的所有权限

# ginfo.permissions.all()

```

权限操作

```

# 读取所有权限信息

Permission.objects.all()

# 读取所有权限信息,并排除以Can开头的系统默认生成权限

Permission.objects.exclude(name__istartswith='Can')

```

[检测用户是否登录,装饰器](https://docs.djangoproject.com/en/1.11/topics/auth/default/#the-login-required-decorator)

```

from django.contrib.auth.decorators import login_required

@login_required(login_url='/login/')

```

[检测用户权限,装饰器](https://docs.djangoproject.com/en/1.11/topics/auth/default/#the-permission-required-decorator)

```

from django.contrib.auth.decorators import permission_required

@permission_required('demo.add_goods',raise_exception=True)

```

[验证用户](https://docs.djangoproject.com/en/1.11/topics/auth/default/#django.contrib.auth.authenticate)

```

from django.contrib.auth import authenticate

user = authenticate(request, username=username, password=password)

```

[用户登录](https://docs.djangoproject.com/en/1.11/topics/auth/default/#how-to-log-a-user-in)退出

```

from django.contrib.auth import login,logout

用户登陆

login(request, user)

用户退出

logout(request)

```

获取用户及权限信息

```

# 获取当前会话的用户对象

obj = get_user(request)

# 获取当前用户拥有的所有权限

pms = obj.get_all_permissions()

# # 检查当前用户是否具有 perm 权限

# res = obj.has_perm('demo.add_types')

```

[自定义权限](https://docs.djangoproject.com/en/1.11/topics/auth/customizing/#custom-permissions)

> 要为给定的模型对象创建自定义权限,请使用permissions 模型元属性。

>

> 此示例任务模型创建三个自定义权限,即用户可以使用或不能对Task应用程序执行的操作,这些操作特定于您的应用程序:

```

class Task(models.Model):

...

class Meta:

permissions = (

("view_task", "Can see available tasks"),

("change_task_status", "Can change the status of tasks"),

("close_task", "Can remove a task by setting its status as closed"),

)

```

模板中操作

```

获取当前会话用户

{ { request.user.username } }

获取当前会话用户权限 https://docs.djangoproject.com/en/1.11/topics/auth/default/#permissions

{ { perms } }

判断当前用户是否具有权限

{ % if request.user.is_superuser or 'demo.show_users' in perms % }

<li>用户管理</li>

{ % endif % }

```

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
多因子身份认证
多因子身份认证(Multi-factor Authentication Service,MFAS)的目的是建立一个多层次的防御体系,通过结合两种或三种认证因子(基于记忆的/基于持有物的/基于生物特征的认证因子)验证访问者的身份,使系统或资源更加安全。攻击者即使破解单一因子(如口令、人脸),应用的安全依然可以得到保障。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档