当前位置: 首页 > news >正文

django+drf+vue 简单系统搭建 (4) 用户权限

权限控制是web中的重要组成部分。与以往的博客系统不同,本次工具页面仅支持注册用户。

每个注册用户都能访问到工具页面,并且提交自己的task来选择具体的工具来处理自己提交的文件。每个注册用户都只能访问到自己提交的task,而管理员则可以查看所有task。

1. 权限控制

我们先来设置工具相关页面权限,我们规定只有注册用户才能访问:

全局权限控制

修改setting,添加在installed_apps之后

# settings.py
REST_FRAMEWORK = {'DEFAULT_PERMISSION_CLASSES':['rest_framework.permissions.IsAuthenticated',]
}
  • 限制访问:最简单的权限是允许通过身份验证的用户访问,并拒绝未经身份验证的用户访问,这对应于rest_framework中的IsAuthenticated类。

自定义权限控制

在views中添加permissions信息

#simpletool/views.pyfrom simpletool.permissions import IsAuthenticatedOrAdmin
# Create your views here.class simpletoolList(generics.ListCreateAPIView):queryset = simpleTool.objects.all()serializer_class = ToolListSerializerpermission_classes = [IsAuthenticatedOrAdmin]class simpletoolDetail(generics.RetrieveUpdateDestroyAPIView):queryset = simpleTool.objects.all()serializer_class = ToolDetailSerializerpermission_classes = [IsAuthenticatedOrAdmin]

补充permissions.py文件

from rest_framework import permissionsclass IsAuthenticatedOrAdmin(permissions.IsAuthenticated):def has_permission(self, request, view):# 对注册用户开放操作# if request.method in permissions.SAFE_METHODS:if (request.user.is_authenticated) and (request.method in permissions.SAFE_METHODS): return True# 仅管理员可进行其他操作return request.user.is_superuser

permission_classes 可以接收一个列表,因此权限控制类可以设置多个,请求必须满足所有控制条件才允许被放行。

现在来让我们看一下直接访问时的状况:

http http://127.0.0.1:8000/api/simpletool/

创建一个普通用户

 

 测试权限

http -a john:123456 http://127.0.0.1:8000/api/simpletool/

 测试PUT权限

http -a john:123456 POST http://127.0.0.1:8000/api/simpletool/ title="test_tool"

 管理员权限测试

http -a xiaofan0101:123456 POST http://127.0.0.1:8000/api/simpletool/ title="test_tool"

http://www.lryc.cn/news/248166.html

相关文章:

  • stm32 计数模式
  • rss服务搭建记录
  • GEE 23:基于GEE实现物种分布模型之随机森林法
  • HCIE 01:基于前缀列表的BGP ORF功能
  • 基于SSM的云鑫曦科技办公自动化管理系统设计与实现
  • Angular项目中如何管理常量?
  • 【机器学习 | 可视化】回归可视化方案
  • 树与二叉树堆:链式二叉树的实现
  • C++面试的一些总结day1:指针和引用的区别
  • Java核心知识点整理大全15-笔记
  • 初始本地仓库推送到远程仓库-git
  • OpenCV | 图像梯度sobel算子、scharr算子、lapkacian算子
  • WS2812灯条基于WLED开源项目无门槛使用简介
  • 基于AOP的声明式事物控制
  • 第七节HarmonyOS UIAbility生命周期以及启动模式
  • matlab设置背景颜色
  • Linux gzip命令用法详解:如何压缩和解压文件(附实例教程和注意事项)
  • 初刷leetcode题目(11)——数据结构与算法
  • 基于SSM框架的图书馆管理系统设计与实现
  • 【面试】css预处理器之sass(scss)
  • Android设计模式--享元模式
  • 人工智能对我们的生活影响有多大
  • 【蓝桥杯选拔赛真题26】C++字符串逆序 第十三届蓝桥杯青少年创意编程大赛C++编程选拔赛真题解析
  • antd vue a-select 下拉框位置偏移
  • Windows10免安装PostgreSQL
  • lua_next
  • svn服务端安装
  • 基于C#实现十字链表
  • 【MySQL】常用内置函数:数值函数 / 字符串函数 / 日期函数 / 其他函数
  • Python内置函数与标准库函数的详细解读