1 认证

# 登录认证---》某个接口必须登录后才能房屋
# 登录接口---》登录成功返回随机字符串---》携带随机字符串【认证】 通过,再继续访问某个接口
# 读APIView源码时,三大认证---》视图类的方法之前执行的----》drf提供了很方便的写认证


# 写一个登录接口
-用户表,用户token表
   -前端传入用户名密码----》视图类---》登录方法---》校验用户名密码是否正确,如果正确 生成随机字符串存入数据库---》把随机字符串返回给前端
   
# 随便写个接口---》登录后才能访问
# 写认证类
-第一步:写一个类,继承BaseAuthentication
   -第二步:在类中重写authenticate方法
   -第三步:在方法中做验证,如果通过,返回两个值,如果不通过,抛AuthenticationFailed的异常
   
# 使用认证类
-局部使用-->视图类中
       class BookView(APIView):
           authentication_classes = [LoginAuth,]
   -全局使用---》配置文件
  REST_FRAMEWORK = {
           # 全局使用认证类
           'DEFAULT_AUTHENTICATION_CLASSES':['app01.auth.LoginAuth',]
      }
       
   -局部禁用
    class BookView(APIView):
        authentication_classes = []

# 前端调用接口时
http://127.0.0.1:8000/user/books?token=27954a0e-9b0b-442d-8aff-839ec9f70960

1.1 登录接口

模型类

class User(models.Model):
   username = models.CharField(max_length=32)
   password = models.CharField(max_length=32)
class UserToken(models.Model):
   token = models.CharField(max_length=32)  # 用户登录成功签发的随机字符串
   user = models.OneToOneField(to='User',on_delete=models.CASCADE)

路由

from rest_framework.routers import SimpleRouter
from .views import UserView,BookView
router=SimpleRouter()
router.register('user',UserView,'user')
urlpatterns = [
]
urlpatterns+=router.urls

视图类

class UserView(ViewSet):
   authentication_classes = []  # 局部禁用
   # 127.0.0.1:8080/user/user/login--->post
   @action(methods=['post', ], detail=False)
   def login(self, request):
       # 取出用户名密码---》去数据库查询---》有就登录成功(生成随机字符串存入数据),没有就登录失败
       username = request.data.get('username')
       password = request.data.get('password')
       user = User.objects.filter(username=username, password=password).first()
       if user:
           # 登录成功
           # 生成一个随机字符串---》uuid--》生成一个随机不重复的值
           token = str(uuid.uuid4())  # python 动态强类型
           # 存到UserToken表中---》两种情况:之前有了就更新,之前没有就新增
           # 有就更新,没有就修改
           # defaults=None, **kwargs:传入的去查询,如果能查到使用defaults给的更新
           UserToken.objects.update_or_create(user=user, defaults={'token': token})
           # UserToken.objects.update_or_create( defaults={'token': token},kwargs={'user':user})
           return Response({'code': 100, 'msg': '登录成功', 'token': token})

       else:
           return Response({'code': 101, 'msg': '用户名或密码错误'})

1.2 认证类


from rest_framework.authentication import BaseAuthentication
from rest_framework.exceptions import AuthenticationFailed
from .models import UserToken
class LoginAuth(BaseAuthentication):
   def authenticate(self, request):
       # 做验证,验证用户是否登录
       # 放到请求地址中/请求头中
       token=request.query_params.get('token')
       # 去数据库查 token在不在
       user_token=UserToken.objects.filter(token=token).first()
       if user_token:
           # 验证通过了,返回两个值,第一个值是当前登录用户,第二个值是token
           return user_token.user,token
       else:
           # 验证失败
           raise AuthenticationFailed('小伙子,您没有登录,不能访问')

2 权限

# 登录成功了,但是有的接口区分权限,有的人有权限,有的人没权限
# 用户表新增一个 用户类型字段:超级管理员,普通管理员,普通用户


# 权限类的写法
-第一步:写一个类,继承BasePermission
   -第二步:重写has_permission方法
   -第三步:在has_permission中,进行权限的判断,如果有权限,返回True,如果没有权限,返回False,返回的中文提示信息,使用message字段标识
   
   
#权限类的使用
-局部使用-->视图类中
       class BookView(APIView):
            permission_classes = [PermissionAuth,]
   -全局使用---》配置文件
  REST_FRAMEWORK = {
           # 全局使用认证类
           'DEFAULT_PERMISSION_CLASSES':['app01.auth.PermissionAuth',]
      }
       
   -局部禁用
    class BookView(APIView):
        permission_classes = []

补充

# python 是动态强类型语言    
# go   是静态强类型语言
# java   是静态强类型语言---》隐士类型转换
#js     是动态弱类型语言

# 动态:解释型语言
# 强弱指的是:数据类型强:不同类型之间不允许之间运算
# 弱类型:不同类型之间不需要转换可以之间运算



# 健壮性----鲁棒性

drf认证与权限的更多相关文章

  1. DRF 认证、权限、限制

    DRF 认证.权限.限制   认证: 定义一个用户表和一个保存用户的Token表 # ======================day96======================= class ...

  2. drf 认证、权限、限流、过滤、排序、分页器

    认证Authentication 准备工作:(需要结合权限用) 1. 需要使用到登陆功能,所以我们使用django内置admin站点并创建一个管理员. python manage.py creates ...

  3. drf认证、权限、限流

    认证Authentication(5星) 认证逻辑及编写步骤 逻辑 认证类:用来校验用户是否登录,如果登录了,继续往下走,如果没有登录,直接返回 编写步骤 -第一步:写一个类,继承BaseAuthen ...

  4. 2. DRF 认证、权限、限流、分页、过滤、序列 化

    2.1 user/urls.py   ModelViewSet注册路由三部曲 from django.urls import include, path from user import views ...

  5. DRF之版本控制、认证和权限组件

    一.版本控制组件 1.为什么要使用版本控制 首先我们开发项目是有多个版本的当我们项目越来越更新,版本就越来越多,我们不可能新的版本出了,以前旧的版本就不进行维护了像bootstrap有2.3.4版本的 ...

  6. 三 drf 认证,权限,限流,过滤,排序,分页,异常处理,接口文档,集xadmin的使用

    因为接下来的功能中需要使用到登陆功能,所以我们使用django内置admin站点并创建一个管理员. python manage.py createsuperuser 创建管理员以后,访问admin站点 ...

  7. python 全栈开发,Day97(Token 认证的来龙去脉,DRF认证,DRF权限,DRF节流)

    昨日内容回顾 1. 五个葫芦娃和三行代码 APIView(views.View) 1. 封装了Django的request - request.query_params --> 取URL中的参数 ...

  8. (四) DRF认证, 权限, 节流

    一.Token 认证的来龙去脉 摘要 Token 是在服务端产生的.如果前端使用用户名/密码向服务端请求认证,服务端认证成功,那么在服务端会返回 Token 给前端.前端可以在每次请求的时候带上 To ...

  9. DRF的版本、认证、权限

    DRF的版本 版本控制是做什么用的, 我们为什么要用 首先我们要知道我们的版本是干嘛用的呢~~大家都知道我们开发项目是有多个版本的~~ 当我们项目越来越更新~版本就越来越多~~我们不可能新的版本出了~ ...

  10. DRF(4) - 认证、权限组件

    一.引入 通过前面三节课的学习,我们已经详细了解了DRF提供的几个重要的工具,DRF充分利用了面向对象编程的思想,对Django的View类进行了继承,并封装了其as_view方法和dispatch方 ...

随机推荐

  1. Docker 数据迁移到数据盘

    systemctl stop docker 找到新的.空间较达的磁盘路径,然后创建任意目录.例如: mkdir /data/docker mv /var/lib/docker /data/docker ...

  2. 如何搭建Redis集群(主从+哨兵)

    一.什么是redis主从复制? 主从复制,是指将一台Redis服务器的数据,复制到其他的Redis服务器.前者称为主节点(master),后者称为从节点(slave),数据的复制是单向的,只能由主节点 ...

  3. mac 编译安装ffmpeg

    下载源码: https://ffmpeg.org/download.html 解压, ./configure --disable-x86asm --prefix=/usr/local/ffmpeg_m ...

  4. 在VSCODE的终端运行Python时汉字乱码问题处理

    问题描述 在VSCODE的终端运行Python时,打印输出中文时汉字出现乱码, 文件编码都是UTF-8 解决步骤 1.打开Settings配置窗口(Ctrl+,) 2.搜索:code-runner.e ...

  5. C# Linq查本集合中不包含于另一个集合的元素

    public void Linq() { List<Product> products = GetProductList(); List<Customer> customers ...

  6. Spark之详解及性能优化

    一.spark简介 Apache Spark是一个围绕速度.易用性和复杂分析构建的大数据处理框架. Spark是用Scala程序设计语言编写而成,运行于Java虚拟机(JVM)环境之上.目前支持如下程 ...

  7. C#textbox更改字体颜色只读后不起作用的解决办法

    textbox的属性ReadOnly设置为true只读后,只更改字体颜色并不起作用. 解决办法是,连同背景色一起设置即可. textBox1.BackColor =textBox1.BackColor ...

  8. JavaScript异步概念及与c#异步的区别

    JS的异步操作函数往往是通过回调函数来实现异步任务的结果处理,在ES6之前如setTimeout函数和异步AJAX编程: 在ES6规范后Promise 类对象使得书写异步任务更加容易,返回Promis ...

  9. js 三维数组转对象数组 二维数组转对象数组

    1. 三维数组转对象数组   输出: 代码如下: let dataArr = [ [ [109.654541015625, 29.34387539941801], [110.467529296875, ...

  10. Visaul Studio 快捷方式

    1.删除光标所在行:Ctrl + shift + L : 2.剪切光标所在行:Ctrl + X : 3.在光标上方插入一行:Ctrl + Enter : 4.注释代码:Ctrl + K --> ...