访问频率(节流)

1.某个用户一分钟之内访问的次数不能超过3次,超过3次则不能访问了,需要等待,过段时间才能再访问。

2.自定义访问频率。两个方法都必须写上。

登入页面的视图加上访问频率

3.返回值False,则不能访问

4.返回值True,则能访问

上面的节流太简单粗暴了,接下来加上一些判断。先获取用户IP

节流源码

1.

2.remote_addr = request.META.get('REMOTE_ADDR')  获取IP地址

3.获取IP地址

4.print(remote_addr)   打印用户的ID

5.保存用户的所有记录,先定义一个全局的变量。(可以放数据库、缓存)

6.为了逻辑更清晰,我们让时间近的,放到列表的最前面(就是列表的左端)。

只要访问时间超过一分钟,我们就删掉他。

如果一分钟内已经访问三次了,第四次访问时就会被拒绝。

等到最早的一个访问时间超过一分钟被删掉,就可以继续访问了。

用while循环,可以把所有过期的时间都删掉。

被拒绝

7.wait方法:提示需要等待多少秒才能访问。

运行结果

8.等待时间不能写死,应该的动态的。

运行结果:

节流源码流程

1.

2.

3.

4.

5.全局配置文件

6.局部配置

7.check_throttles 方法执行每一个节流的 allow_request方法。

8.allow_request 如果返回的False,则抛出异常。

9.超出访问次数,抛出异常。

10.wait 把提示时间拿到,还剩多少秒。

全局配置

把访问频率的类放到app01.utils.throttle.py文件里

全局配置settings.py里面

内置控制频率类  from rest_framework.throttling import BaseThrottle

1.源码:

2.继承内置控制频率类。

3. class SimpleRateThrottle(BaseThrottle):

4.

SimpleRateThrottle:源码流程

1.请求一进来先执行构造方法。__init__()

2.get_rate()  取scope的值。

3.THROTTLE_RATES  去全局配置文件取值

4.配置全局文件settings.py.

接下来我们定义一个30秒访问10次的频率。

setting.py文件写一条配置。内部有自动实现30秒10次!!!

如果是我们自己写的,就必须改源码。内置的只要传参即可。

5.设置为每分钟3次

6.rate = 3/m  获取到值

7.进行分割rate,分别那种次数、时间

8.

9.自己写get_cache_key方法

10.继续源码

11.缓存

12.符合条件,访问成功,返回True

13.访问次数太多,返回False ,不能访问。

14.提示时间也给我们写好了,不用自己写。

15.所以4行代码就搞定啦,再加上配置。

运行结果:

正常访问

请求超过3次就抛异常。

问题:能不能让当前登入用户也做这样的操作?

1.对登入用户的控制访问频率。

2.setting.py  已登入的用户10/m

views.py

登入api 局部设置(单独设置) 匿名访问频率 3/m. 其他api都默认用全局的。

运行结果:OrderView订单api 、UserInfoView用户信息api 都是默认用全局已登入访问频率的配置。匿名用户3/m,超过3次就不能再访问啦。

http://127.0.0.1:8011/app01/v1/auth/

三次访问以后

已登陆用户访问的就不写了,自己悟,很简单。

rest_framework之频率详解 03的更多相关文章

  1. django rest_framework 序列化组件详解

    为什么要用序列化组件 当我们做前后端分离的项目,我们前后端交互一般都选择JSON数据格式,JSON是一个轻量级的数据交互格式. 那么我们给前端数据的时候都要转成json格式,那就需要对我们从数据库拿到 ...

  2. rest_framework之序列化详解 06

    拿到所有的角色数据 1.urls.py 2.models.py  假设只有3个角色 3.views.py from api import models import json json只能序列化pyt ...

  3. rest_framework之版本详解 04

    访问不同版本,给不同内容. rest规范:版本要么放url上:要么放请求头里. 1.原来的url的版本都写死了.只能写v1 from django.conf.urls import url from ...

  4. rest_framework之规范详解 00

    接口开发 方式1:缺点:如果有10张表,则需要40个url. urls.py views.py 缺点:如果有10张表,则需要40个url.    接下来就出现了resrful 规范,比较简洁 方式2: ...

  5. 21个项目玩转深度学习:基于TensorFlow的实践详解03—打造自己的图像识别模型

    书籍源码:https://github.com/hzy46/Deep-Learning-21-Examples CNN的发展已经很多了,ImageNet引发的一系列方法,LeNet,GoogLeNet ...

  6. 小甲鱼PE详解之IMAGE_OPTIONAL_HEADER32 结构定义即各个属性的作用(PE详解03)

    咱接着往下讲解IMAGE_OPTIONAL_HEADER32 结构定义即各个属性的作用! (视频教程:http://fishc.com/a/shipin/jiemixilie/) 接着我们来谈谈 IM ...

  7. IO模型(epoll)--详解-03

    写在前面 epoll是开发linux高性能服务器的必备技术至,epoll本质,是服务端程序员的必须掌握的知识. 七.epoll的原理和流程 本节会以示例和图表来讲解epoll的原理和流程. 创建epo ...

  8. RFC2544学习频率“Learning Frequency”详解—信而泰网络测试仪实操

    在RFC2544中, 会有一个Learning Frequency的字段让我们选择, 其值有4个, 分别是learn once, learn Every Trial, Learn Every Fram ...

  9. 【转】小波与小波包、小波包分解与信号重构、小波包能量特征提取 暨 小波包分解后实现按频率大小分布重新排列(Matlab 程序详解)

    转:https://blog.csdn.net/cqfdcw/article/details/84995904 小波与小波包.小波包分解与信号重构.小波包能量特征提取   (Matlab 程序详解) ...

随机推荐

  1. Vector & ArrayList Hashtable & HashMap ArrayList & LinkedList

    1. Vector & ArrayList 1)  Vector的方法都是同步的(Synchronized),是线程安全的(thread-safe),而ArrayList的方法不是,由于线程的 ...

  2. android 虚拟键盘控制

    软键盘显示的原理 软键盘的本质是什么?软键盘其实是一个Dialog! InputMethodService为我们的输入法创建了一个Dialog,并且将该Dialog的Window的某些参数(如Grav ...

  3. 关于ARM中的tst、cmp、bne、beq指令

    一.关于cmp的详细用法 假设现在AX寄存器中的数是0002H,BX寄存器中的数是0003H. 执行的指令是:CMP AX, BX 执行这条指令时,先做用AX中的数减去BX中的数的减法运算. 列出二进 ...

  4. Android代码的几点小技巧

     1)View的状态保存与恢复dispatchRestoreInstanceStateonRestoreInstanceStateonSaveInstanceState 2)Service的前台服务使 ...

  5. 将ORACLE数据库更改为归档模式;写出步骤

    解答:具体步骤如下: 1),以exp方式在线备份数据库到指定位置: 2),观察当前数据库是以服务器参数文件(spfile)方式启动还是以参数文件(pfile)方式启动: SQL> show pa ...

  6. Shader开发之三大着色器

    固定功能管线着色器Fixed Function Shaders 固定功能管线着色器的关键代码一般都在Pass的材质设置Material{}和纹理设置SetTexture{}部分. Shader &qu ...

  7. WiFi(网络)调试Android手机

    手机需要root 使用adb tcpip命令开启网络调试功能,一旦手机重启,又要重复这些步骤,比较麻烦. 一劳永逸的方法是,使用re管理器(给予root权限)在手机的/system/build.pro ...

  8. OpenCV学习:Mat结构中的数据共享机制

    使用Mat类,内存管理变得简单,不再像使用IplImage那样需要自己申请和释放内存. Mat是一个类,由两个数据部分组成:矩阵头(包含矩阵尺寸,存储方法,存储地址等信息)和一个指向存储所有像素值的矩 ...

  9. Makefile--基本规则(零)

    [版权声明:转载请保留出处:周学伟:http://www.cnblogs.com/zxouxuewei/] 一般一个稍大的linux项目会有很多个源文件组成,最终的可执行程序也是由这许多个源文件编译链 ...

  10. laravel 5.3 多用户认证

    不知道对不对,乱来一下!!!! 1)laravel自带了一个用户认证系统,要使用的话,直接运行一下命令就可以用了 php artisan make:auth 会生成相应的控制器.路由和模版文件 2)数 ...