DRF认证组件分析

DRF认证组件分析

在开发API过程中,有些功能需要登录才能访问,有些无需登录。drf中的认证组件主要就是用来实现此功能。

0 认证组件的三种返回值
  • 认证成功,返回元组(user, auth)同时赋值给request.userrequest.auth

    request.user = user, request.auth = auth

  • 认证失败,抛出异常,返回错误信息

  • 返回None

注意,认证组件中,如果是使用了多个认证类,会按照顺序逐一执行其中的authenticate方法:

  • 无论认证成功还是失败,都会有返回值且不为None,就不会走下面的认证类
  • 只有前一个返回值为None时,才会执行下一个认证类
  • 若是所有的认证类的返回值都为None,此时request.userrequest.auth都为空,即匿名用户

如果想匿名用户也可以访问视图,可以在settings.py中配置,有两种配置方法

  • 设为None
    在这里插入图片描述

  • 除了可以定义为None,也可以定义为一个函数,request.userrequest.auth就分别对应两个函数的返回值

    在这里插入图片描述

1 单视图应用

authentication_classes是一个列表,可以同时应用多个认证组件

在这里插入图片描述

2 多视图应用

此时,就需要用到drf的全局配置**(认证组件的类不能放在视图view.py中,会因为导入APIView导致循环引用)。**

在这里插入图片描述

3 单视图多视图结合

在drf中,默认优先去全局中读取,再去视图类中读取。

我们可以将个别视图类的authentication_classes列表置为空

在这里插入图片描述

4 源码分析

在这里插入图片描述

  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值