Django 限制访问频率的思路详解
作者:h4ck 时间:2021-08-17 16:52:57
最近做了一个系统由于部分接口需要进行耗时操作,因而不希望用户进行频繁访问,需要进行访问频率限制。如果要自己实现一个访问限制功能相对来说也不会太复杂,并且网上有各种代码可以参考。如果自己不想实现这个代码可以使用 Django Ratelimit 。
Django Ratelimit is a ratelimiting decorator for Django views.
https://travis-ci.org/jsocol/django-ratelimit.png?branch=master Code: https://github.com/jsocol/django-ratelimit License: Apache Software License Issues: https://github.com/jsocol/django-ratelimit/issues Documentation: http://django-ratelimit.readthedocs.org/
使用方法也相对来说比较简单:
@ratelimit(key='ip', rate='5/m')
def myview(request):
# Will be true if the same IP makes more than 5 POST
# requests/minute.
was_limited = getattr(request, 'limited', False)
return HttpResponse()
@ratelimit(key='ip', rate='5/m', block=True)
def myview(request):
# If the same IP makes >5 reqs/min, will raise Ratelimited
return HttpResponse()
@ratelimit(key='post:username', rate='5/m', method=['GET', 'POST'])
def login(request):
# If the same username is used >5 times/min, this will be True.
# The `username` value will come from GET or POST, determined by the
# request method.
was_limited = getattr(request, 'limited', False)
return HttpResponse()
@ratelimit(key='post:username', rate='5/m')
@ratelimit(key='post:tenant', rate='5/m')
def login(request):
# Use multiple keys by stacking decorators.
return HttpResponse()
@ratelimit(key='get:q', rate='5/m')
@ratelimit(key='post:q', rate='5/m')
def search(request):
# These two decorators combine to form one rate limit: the same search
# query can only be tried 5 times a minute, regardless of the request
# method (GET or POST)
return HttpResponse()
@ratelimit(key='ip', rate='4/h')
def slow(request):
# Allow 4 reqs/hour.
return HttpResponse()
rate = lambda r: None if request.user.is_authenticated else '100/h'
@ratelimit(key='ip', rate=rate)
def skipif1(request):
# Only rate limit anonymous requests
return HttpResponse()
@ratelimit(key='user_or_ip', rate='10/s')
@ratelimit(key='user_or_ip', rate='100/m')
def burst_limit(request):
# Implement a separate burst limit.
return HttpResponse()
@ratelimit(group='expensive', key='user_or_ip', rate='10/h')
def expensive_view_a(request):
return something_expensive()
@ratelimit(group='expensive', key='user_or_ip', rate='10/h')
def expensive_view_b(request):
# Shares a counter with expensive_view_a
return something_else_expensive()
@ratelimit(key='header:x-cluster-client-ip')
def post(request):
# Uses the X-Cluster-Client-IP header value.
return HttpResponse()
@ratelimit(key=lambda r: r.META.get('HTTP_X_CLUSTER_CLIENT_IP',
r.META['REMOTE_ADDR'])
def myview(request):
# Use `X-Cluster-Client-IP` but fall back to REMOTE_ADDR.
return HttpResponse()
不过需要注意如果和django rest framwork一起使用的话,要将Ratelimit 装饰器放到第一行,如下:
@ratelimit(key='user', rate='1/3s', block=True, method=ratelimit.ALL)
@api_view(['POST', 'GET'])
@csrf_exempt
def api_get_level(request):
否则会导致如下的错误信息:
IndexError at /rest-api/level/
tuple index out of range
Request Method: GET
Request URL: http://192.168.1.195:8006/rest-api/level/
Django Version: 2.2.7
Exception Type: IndexError
Exception Value:
tuple index out of range
Exception Location: F:\PyCharmProjects\server\venv\lib\site-packages\ratelimit\decorators.py in _wrapped, line 23
Python Executable: F:\PyCharmProjects\server\venv\Scripts\python.exe
Python Version: 3.7.5
Python Path:
['F:\\PyCharmProjects\\server\\TaichiGameServer',
'I:\\Python37-64\\python37.zip',
'I:\\Python37-64\\DLLs',
'I:\\Python37-64\\lib',
'I:\\Python37-64',
'F:\\PyCharmProjects\\server\\venv',
'F:\\PyCharmProjects\\server\\venv\\lib\\site-packages',
'F:\\PyCharmProjects\\server\\venv\\lib\\site-packages\\setuptools-39.1.0-py3.7.egg']
Server time: Tue, 24 Dec 2019 09:49:01 +0800
Traceback (most recent call last):
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\core\handlers\exception.py", line 34, in inner
response = get_response(request)
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\core\handlers\base.py", line 115, in _get_response
response = self.process_exception_by_middleware(e, request)
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\core\handlers\base.py", line 113, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\views\decorators\csrf.py", line 54, in wrapped_view
return view_func(*args, **kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\views\generic\base.py", line 71, in view
return self.dispatch(request, *args, **kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\rest_framework\views.py", line 505, in dispatch
response = self.handle_exception(exc)
File "F:\PyCharmProjects\server\venv\lib\site-packages\rest_framework\views.py", line 465, in handle_exception
self.raise_uncaught_exception(exc)
File "F:\PyCharmProjects\server\venv\lib\site-packages\rest_framework\views.py", line 476, in raise_uncaught_exception
raise exc
File "F:\PyCharmProjects\server\venv\lib\site-packages\rest_framework\views.py", line 502, in dispatch
response = handler(request, *args, **kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\rest_framework\decorators.py", line 50, in handler
return func(*args, **kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\django\views\decorators\csrf.py", line 54, in wrapped_view
return view_func(*args, **kwargs)
File "F:\PyCharmProjects\server\venv\lib\site-packages\ratelimit\decorators.py", line 23, in _wrapped
request = args[1]
IndexError: tuple index out of range
总结
以上所述是小编给大家介绍的Django 限制访问频率的思路详解网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
来源:http://www.h4ck.org.cn/2019/12/django-限制访问频率/
标签:Django,访问,频率
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
:hover在IE6下的问题
2009-06-18 21:09:00
Django web自定义通用权限控制实现方法
2021-07-31 06:21:09
asp事务处理的另外一个方法
2010-05-27 12:18:00
perl批量查询ip归属地的方法代码
2023-08-11 22:53:54
对Python强大的可变参数传递机制详解
2021-06-23 02:54:09
详解pandas的外部数据导入与常用方法
2023-05-15 19:15:11
Python读取txt文件数据的方法(用于接口自动化参数化数据)
2023-12-28 03:21:52
![](https://img.aspxhome.com/file/2023/9/66419_0s.png)
Python实现Word文档转换Markdown的示例
2022-06-24 08:23:29
![](https://img.aspxhome.com/file/2023/6/67296_0s.png)
numpy的Fancy Indexing和array比较详解
2022-05-12 23:31:46
Python列表(List)知识点总结
2023-11-04 00:01:35
asp连接mysql数据库详细实现代码
2012-12-04 19:56:39
Python编辑器Pycharm安装配置超详细教程
2023-03-25 14:55:15
![](https://img.aspxhome.com/file/2023/2/101062_0s.jpg)
python 如何调用 dubbo 接口
2022-09-28 13:20:13
Python实现EXCEL表格的排序功能示例
2021-05-17 20:50:11
![](https://img.aspxhome.com/file/2023/7/81727_0s.jpg)
python实现按首字母分类查找功能
2023-10-13 11:05:09
python基础教程之python消息摘要算法使用示例
2023-07-03 20:06:00
![](https://img.aspxhome.com/file/2023/9/96969_0s.jpg)
Javascript实现通过选择周数显示开始日和结束日的实现代码
2023-08-23 13:44:52
网页栅格系统研究:960的秘密
2008-10-24 17:03:00
![](https://img.aspxhome.com/file/UploadPic/200810/24/2008102417649857s.jpg)
Python利用正则表达式匹配并截取指定子串及去重的方法
2021-05-07 00:37:20
python 根据网易云歌曲的ID 直接下载歌曲的实例
2021-01-15 19:48:47
![](https://img.aspxhome.com/file/2023/5/101205_0s.jpg)