- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解Django-restframework 之频率源码分析由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
一 前言。
经过权限判断之后就是进行频率的判断了,而频率的判断和权限又不一样,认证、权限和频率的执行流程都差不多,使用配置里面的相关类来进行判断。而不和认证和权限一样,频率的配置没有,查看 apiview 的类属性如下:
二 频率组件执行流程 。
虽然 restframework 原生灭有配置频率,但是提供了几个进行频率判断的类,如下:
其中 simpleratethrottle 类是根据访问者 ip 来进行频率限制的一个类,来看看这个类的执行流程.
1. init方法 。
2. get_rate 。
3. 执行 allow_request方法 。
4. get_cache_key 。
5. 时间差判断 。
6. throttle_success 。
认证失败的话执行 throttle_failure ,其实就是返回 false .
7. wait 。
三 自定义频率组件 。
1. 自定义频率类 。
频率类需要继承自带的频率类 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
# from rest_framework.throttling import basethrottle
class
bookthrottle(basethrottle):
visit_record
=
{}
def
__init__(
self
):
self
.history
=
none
def
allow_request(
self
, request, view):
print
(request.meta)
remote_addr
=
request.meta.get(
'remote_addr'
)
import
time
ctime
=
time.time()
if
remote_addr
not
in
self
.visit_record:
self
.visit_record[remote_addr]
=
[ctime,]
return
true
self
.history
=
self
.visit_record.get(remote_addr)
while
self
.history
and
ctime
-
self
.history[
-
1
] >
60
:
self
.history.pop()
if
len
(
self
.history) <
3
:
self
.history.insert(
0
, ctime)
return
true
else
:
return
false
def
wait(
self
):
import
time
ctime
=
time.time()
return
60
-
(ctime
-
self
.history[
-
1
])
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
# 频率类代码注释
# 访问频率的逻辑
# # {'ip地址':[16:13:39,16:13:19,],'ip地址2':[时间1,时间2],}
# # (1)取出访问者ip
# # (2)判断当前ip不在访问字典里,添加进去,并且直接返回true,表示第一次访问,在字典里,继续往下走
# # (3)循环判断当前ip的列表,有值,并且当前时间减去列表的最后一个时间大于60s,把这种数据pop掉,这样列表中只有60s以内的访问时间,
# # (4)判断,当列表小于3,说明一分钟以内访问不足三次,把当前时间插入到列表第一个位置,返回true,顺利通过
# # (5)当大于等于3,说明一分钟内访问超过三次,返回false验证失败
# #(1)取出访问者ip
# # print(request.meta)
# # remote_addr 就是访问者的ip:127.0.0.1
# ip=request.meta.get('remote_addr')
# import time
# # 获取当前时间
# ctime=time.time()
# # (2)判断当前ip不在访问字典里,添加进去,并且直接返回true,表示第一次访问
# if ip not in self.visit_record:
# self.visit_record[ip]=[ctime,]
# # {'127.0.0.1':[时间1,时间1,]}
# return true
# # self.history=[时间1,时间1,]
# self.history=self.visit_record.get(ip)
# # (3)循环判断当前ip的列表,有值,并且当前时间减去列表的最后一个时间大于60s,把这种数据pop掉,这样列表中只有60s以内的访问时间,
# while self.history and ctime-self.history[-1]>60:
# self.history.pop()
# # (4)判断,当列表小于3,说明一分钟以内访问不足三次,把当前时间插入到列表第一个位置,返回true,顺利通过
# # (5)当大于等于3,说明一分钟内访问超过三次,返回false验证失败
# if len(self.history)<3:
# self.history.insert(0,ctime)
# return true
# else:
# return false
|
2. 使用 。
使用很简单,在需要进行频率控制的视图类中定义一个属性 throttle_classes ,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
class
book(apiview):
authentication_classes
=
[authticate_classes.bookauth]
permission_classes
=
[permiss_classes.loginpermission]
throttle_classes
=
[thrott_classes.bookthrottle]
# authentication_classes = []
def
dispatch(
self
, request,
*
args,
*
*
kwargs):
return
super
().dispatch(request,
*
args,
*
*
kwargs)
def
get(
self
, request,
id
):
print
(request.user,
'444'
)
response
=
{
'status'
:
100
,
'msg'
: none}
book_obj
=
models.book.objects.
filter
(pk
=
id
).first()
if
book_obj:
book_ser
=
myser.bookser(book_obj, many
=
false)
response[
'book'
]
=
book_ser.data
else
:
response[
'msg'
]
=
'图书没有对象'
response[
'status'
]
=
101
return
response(response)
|
四 配置自定义频率类 。
1. 局部配置 。
其实上面的就是局部配置, 。
1
2
3
4
|
class
book(apiview):
authentication_classes
=
[authticate_classes.bookauth]
permission_classes
=
[permiss_classes.loginpermission]
throttle_classes
=
[thrott_classes.bookthrottle]
|
2. 全局使用 。
全局配置如下:
1
2
3
|
rest_framework
=
{
'default_throttle_classes'
: [
'app01.thrott_classes.bookthrottle'
]
}
|
3. 局部禁用 。
局部禁用需要在视图类中定义一个空的 throttle_classes 属性 。
1
|
throttle_classes
=
[]
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://www.cnblogs.com/zuanzuan/p/10439590.html 。
最后此篇关于详解Django-restframework 之频率源码分析的文章就讲到这里了,如果你想了解更多关于详解Django-restframework 之频率源码分析的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我对 Python-Django 和 web 开发还很陌生,我被困在这个使用 POST 创建新资源的特殊问题上。 我正在为 REST API 使用 Django REST 框架,我正在尝试创建一个新资
我已经使用 Django-storages 成功地将 Word 文档存储到 S3。 class Document(TitleSlugDescriptionModel, TimeStampedModel
我有 2 个关于模型代理的问题, 如何从模型对象创建代理对象? 如何从模型查询集创建代理查询集? 例如,假设我们定义了: from django.contrib.auth.models import
我想编写一个直接执行 HTTP 请求的单元测试(而不是使用 django.test.client.Client)。 如果您好奇为什么 - 那是因为我想测试我从 Django 应用程序公开的 Thrif
我为我的个人网站启动了一个 django 项目来学习 django。到目前为止,我已经将我的开发环境设置为我需要的一切,并遵循 this很棒的教程来创建一些基本的数据结构和模板。现在我想开始使用我之前
我已经阅读了很多关于如何在使用 Django 注册时添加额外字段的信息,例如 here 、 here 和 here 。代码片段是: forms.py(来自注册应用程序) class Registrat
我正在编写小型社交应用程序。功能之一是在网站标题中写入用户名。因此,例如,如果我登录并且我的名字是Oleg(用户名),那么我应该看到: Hello, Oleg | Click to edit prof
我有一个使用 Django 和 Django Rest 框架开发的应用程序。我想将 django-reversion 功能添加到我的应用程序中。 我已经尝试过http://django-reversi
我有一个简单的 HTML 表单,我没有使用 Django 表单,但现在我想添加一个选择。 选择最容易创建为 Django ChoiceField (与通过循环等手动创建选择相反),但是,如果没有在 D
我不明白为什么人们以两种方式编写外键,这样做的目的是什么?它们是相同还是不同? 我注意到有些人这样写: author = models.ForeignKey(Author, on_delete=mod
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
这对于 Django 1.2 仍然有效吗? Custom Filter in Django Admin on Django 1.3 or below 我已经尝试过,但管理类中的 list_filter
问题在于,当 django-compressor 编译为 .js 文件的 CoffeeScript 文件中引用 {{ STATIC_URL }} 时,它无法正确加载。 在我的 django 模板中,我
我正在尝试将一些字段从一个 django 模型移动到一个新模型。假设我有一个书籍模型: class Book(models.Model): title = models.CharField(max
我想在我的 Django 应用程序中获取评论最多的十个帖子,但我做不到,因为我想不出合适的方法。 我目前正在使用 django 评论框架,并且我已经看到使用 aggregate or annotate
目前我正在寻找在 Django 中实现访问控制。我已经阅读了有关内置权限的内容,但它并不关心每个对象的基础。例如,我想要“只有创建者可以删除自己的项目”之类的权限。所以我读到了 django-guar
嗨,我正在将我的 Django 模型的一个字段的值设置为其他模型的另一个字段的值。这个值应该是动态变化的。 这是我的第一个模型 class MainModel(AbstractBaseUser, Pe
我正在尝试为我的模型创建一个编辑表单。我没有使用模型表单,因为根据模型类型,用户可以使用不同的表单。 (例如,其中一个表单有 Tinymce 小部件,而另一个没有。) 有没有什么方法可以使用模型设置表
Django 模板中的搜索字段 如何在类似于此图像的 Django 模板中创建搜索字段 http://asciicasts.com/system/photos/1204/original/E354I0
根据 Django documentation ,如果 Django 安装激活了 AuthenticationMiddleware,HttpRequest 对象有一个“user”属性代表当前登录的用户
我是一名优秀的程序员,十分优秀!