Django REST Framework之频率限制的使用

作者:学霸初养成 时间:2021-01-25 17:59:42 

开放平台的API接口调用需要限制其频率,以节约服务器资源和避免恶意的频繁调用

使用

自定义频率限制组件:utils/thottle.py


class MyThrottle(BaseThrottle):

def __init__(self):
   self.history = None

def allow_request(self, request, view):
   # 实现限流的逻辑
   # 以IP限流
   # 访问列表 {IP: [time1, time2, time3]}
   # 1, 获取请求的IP地址
   ip = request.META.get("REMOTE_ADDR")
   # 2,判断IP地址是否在访问列表
   now = time.time()
   if ip not in VISIT_RECORD:
     # --1, 不在 需要给访问列表添加key,value
     VISIT_RECORD[ip] = [now,]
     return True
     # --2 在 需要把这个IP的访问记录 把当前时间加入到列表
   history = VISIT_RECORD[ip]
   history.insert(0, now)
   # 3, 确保列表里最新访问时间以及最老的访问时间差 是1分钟
   while history and history[0] - history[-1] > 60:
     history.pop()
   self.history = history
   # 4,得到列表长度,判断是否是允许的次数
   if len(history) > 3:
     return False
   else:
     return True

def wait(self):
   # 返回需要再等多久才能访问
   time = 60 - (self.history[0] - self.history[-1])
   return time

views.py


class TestThrottle(APIView):
 throttle_classes = [MyThrottle, ]

def get(self, request, *args, **kwargs):
   pass
  • allow_request() 方法内定义频率控制的实现

  • wait() 方法的返回值代表了距离下次允许访问还剩多久,单位:秒

全局使用

同样,需要配置setttings文件


EST_FRAMEWORK = {
 "DEFAULT_PERMISSION_CLASSES": [] # 默认的权限类
}

使用REST Framework提供的频率控制组件

DRF提供了四种频率控制组件:

  • SimpleRateThrottle

  • AnonRateThrottle

  • UserRateThrottle

  • ScopedRateThrottle

以SimpleRateThrottle为例:

settings.py


REST_FRAMEWORK = {
 'DEFAULT_THROTTLE_CLASSES':['api.utils.mythrottle.UserThrottle',]
 'DEFAULT_THROTTLE_RATES': {
   '未认证用户': '10/m',
   '已认证用户': '100/h',
 },
}

utils.thorttle.py


from rest_framework.views import APIView
from rest_framework.response import Response
from rest_framework import exceptions
from rest_framework.throttling import SimpleRateThrottle

class VisitThrottle(SimpleRateThrottle):
 scope = "未认证用户"

def get_cache_key(self, request, view):
   return self.get_ident(request)

class UserThrottle(SimpleRateThrottle):
 scope = "已认证用户"

def get_cache_key(self, request, view):
   return request.user # 认证通过后,认证方法authenticate的返回值之一

views.py


class TestThrottle(APIView):<br># 这样设置后,节流功能就会使用VisitThrottle类,而不会使用UserThrottle类
 throttle_classes = [VisitThrottle,]

def get(self, request, *args, **kwargs):

这里使用的节流类是继承了SimplePateThrottle类,而这个类利用了django内置的缓存来存储访问记录。通过全局节流设置,所有的视图类默认是使用UserThrottle类进行节流,如果不想使用默认的类就自定义给throttle_classes属性变量赋值,如:“throttle_classes = [VisitThrottle,]”。

源码分析

1.为什么会使用“scope”属性变量,它有什么用?

Django REST Framework之频率限制的使用

由内置接口代码基本结构中可以看到,视图类TestThrottle继承了SimpleRateThrottle类,跳转到这个类中,就可以看到scope属性变量。

Django REST Framework之频率限制的使用

Django REST Framework之频率限制的使用

由“THROTTLE_RATES[self.scope]”知,scope一定是一个key值,而THROTTLE_RATES不就是在配置文件中所设置的变量吗?所以说scope代表的就是“未认证用户”和“已认证用户”这两个key值,而这两个key值代表的就是不同的节流方案。返回值就这这两个key值所对应的value值,具体是哪一个,那就看视图类TestTrottle中对scope属性变量的值是什么了,如果这个scope值不存在,就会抛出异常。

2.为什么会使用“get_cache_key”方法?该方法的返回值是什么?

在分析get_cache_key方法前,先分析一下SimpleRateThrottle类:

Django REST Framework之频率限制的使用

cache = default_cache 它表示的就是存储用户访问记录的缓存,而这个缓存正是django默认的缓存。

get_rate 方法,前面已经说过了,是用来获取节流方式的。

Django REST Framework之频率限制的使用

parse_rate方法,解析节流方式

Django REST Framework之频率限制的使用

allow_request方法,就是跟在自定义节流方法一样,是实现节流算法的。之所以会用内置节流方法,就是因为在这里,已经实现了节流算法。

Django REST Framework之频率限制的使用

wait方法,就是跟在自定义节流类中的wait方法一样,返回提示用户还有多长时间就可以再次访问了。

Django REST Framework之频率限制的使用

通过初始化方法,获取并解析好要使用的节流方式,供allow_request方法使用。

Django REST Framework之频率限制的使用

通过调用check_throttles方法,来调用allow_request方法,由上面关于allow_request截图来看,要完成它的功能,就必须通过get_cache_key方法获取到当前用户的唯一标识,所以get_cache_key应该返回唯一标识。

Django REST Framework之频率限制的使用

get_cache_key 方法,这就是在视图类TestThrottle中重写的方法。由上图可知,该方法是必须重写的,不然就会抛出异常。

3.为什么会使用“throttle_classes”属性变量,它有什么用?

Django REST Framework之频率限制的使用

通过查看dispatch方法中的intial方法可以看到调用的节流方法“check_throttles”。

Django REST Framework之频率限制的使用

这个for循环返回的一定是一个列表,类似于认证和授权的源码,那么这个列表一定是保存节流类的列表。

Django REST Framework之频率限制的使用

get_throttles方法返回的是一个列表生成式,而这里的throttle_classes就是在视图类TestThrottle中使用的,该变量就保存节流类对象。

4.“DEAFULT_THROTTLE_CLASSES”从哪里来?有什么用?

Django REST Framework之频率限制的使用

通过throttle_classes属性变量,跳转到该图,可以看到配置文件中说的“DEFAULT_THROTTLE_CLASSES”,它是用来通过配置文件settings来对全局节流类进行配置,功能等价于throttle_classes属性变量

5.“DEAFULT_THROTTLE_RATES”从哪里来?有什么用?

Django REST Framework之频率限制的使用

由SimpleRateThrottle类和上文对scope属性变量的分析可知,THROTTLE_RATES就是为了存储在配置文件中设置的不同的节流方法的。

综上所述,可以看出,在利用内置节流接口时,通过配置文件settings的设置和提供该接口所需的用户唯一标识外,不需要我们做再多的操作,这就形成了我们上文写的内置接口代码基本结构的样式。

来源:https://www.cnblogs.com/V587Chinese/p/11569065.html

标签:Django,REST,Framework,频率限制
0
投稿

猜你喜欢

  • 微信小程序wxml列表渲染原理解析

    2023-07-17 14:28:08
  • FCKeditor编辑器添加图片上传功能及图片路径问题解决方法

    2022-12-15 01:07:10
  • Python 可变类型和不可变类型及引用过程解析

    2021-07-13 00:04:27
  • linux中用shell快速安装配置Go语言的开发环境

    2024-02-12 22:38:11
  • 微信小程序新手教程之启动页的重要性

    2023-07-02 05:26:00
  • 文本框textarea限制输入文字个数的方法

    2008-01-28 13:02:00
  • XML卷之实战锦囊(2):动态查询

    2008-09-05 17:20:00
  • python+requests接口自动化框架的实现

    2022-11-25 04:03:40
  • Vue下滚动到页面底部无限加载数据的示例代码

    2024-06-05 15:31:44
  • 基于Python制作B站视频下载小工具

    2023-11-18 11:58:50
  • Python遍历指定文件及文件夹的方法

    2023-04-07 23:10:17
  • PHP中round()函数对浮点数进行四舍五入的方法

    2023-11-23 21:35:24
  • 解析PHP可变函数的经典用法

    2024-06-05 09:38:32
  • Python如何使用cv2.canny进行图像边缘检测

    2021-03-11 20:38:12
  • Python对图片进行resize、裁剪、旋转、翻转问题

    2023-03-01 11:07:05
  • 图解Python中浅拷贝copy()和深拷贝deepcopy()的区别

    2021-12-09 21:09:39
  • python+numpy实现的基本矩阵操作示例

    2023-07-16 13:52:37
  • python实现单机五子棋

    2021-04-26 05:34:35
  • python的函数参数你了解吗

    2021-11-08 16:15:59
  • Python之用户输入的实例

    2022-09-06 13:22:18
  • asp之家 网络编程 m.aspxhome.com