Django 之 restframework 频率组件的使用以及源码分析

频率组件的使用

  • 第一步,先写一个频率类,继承SimpleRateThrottle

    • 一定要在这个类里面配置一个scop=‘字符串’--->字符串用于settings里面配置频率组件
    • 在该类里面重写 get_cache_key, 返回self.get_ident(request)
    from rest_framework.throttling import SimpleRateThrottle
    # 创建一个频率类
    class Throttle(SimpleRateThrottle):
    # 在频率类中配置一个scope
    scope='qzk'
    # 重写 该类中的 get_cache_key 方法
    def get_cache_key(self,request,view):
    # 返回 self.get_ident(request)
    return self.get_ident(request)
  • 第二步,在settings.py文件中配置 频率组件

    # 全局使用认证、权限组件、频率组件
    REST_FRAMEWORK = {
    "DEFAULT_AUTHENTICATION_CLASSES": ["app01.auths.MyAuth", ], # 全局认证组件配置
    "DEFAULT_PERMISSION_CLASSES": ["app01.permissions.MyPermission", ], # 全局权限组件配置
    'DEFAULT_THROTTLE_CLASSES': ['app01.throttles.RateThrottle', ], # 频率组件全局配置
    'DEFAULT_THROTTLE_RATES': {
    'qzk': '3/m' # 控制访问频率为一分钟三次
    } #
    }
  • 第三步,在视图类中使用频率组件

    • 局部使用:在视图类中,配置 throttle_classes=[RateThrottle,]
    from rest_framework.views import APIView
    from rest_framework.response import Response
    from app01 import models
    from app01.myser import BookSerializer # 导入序列化组件
    from app01 import auths # 导入认证组件
    from app01 import throttles # 导入频率组件
    from app01 import permissions # 导入权限组件 class Book(APIView):
    """局部使用三个认证、权限、频率"""
    # 配置认证类列表
    authentication_classes = [auths.MyAuth, ]
    # 配置权限类列表
    permission_classes = [permissions.MyPermission, ]
    # 配置评率认证列表
    throttle_classes = [throttles.RateThrottle, ] # get 获取所有书籍信息
    def get(self, request, id):
    response = {'status': 100, 'msg': '成功'}
    print(id)
    if not id:
    book_list = models.Book.objects.all()
    # 第一个参数是要序列化的queryset对象,如果要序列化多条,必须制定many=True
    # 当instance形参被传入的实参是单个参数的时候,many=False
    book_serializer = BookSerializer(book_list, many=True)
    else:
    print(id)
    book_obj = models.Book.objects.filter(pk=id).first()
    book_serializer = BookSerializer(book_obj, many=False)
    print(book_serializer.data)
    response['books'] = book_serializer.data
    return Response(response) """新增功能"""
    def post(self, request, id):
    response = {'status': 100, 'msg': '成功'}
    # 提交的字典
    book = request.data
    # 传统方法,创建对象保存
    print(book) # 新方法,通过序列化组件保存,必须继承自ModelSerializer
    book_ser = BookSerializer(data=book)
    # is_valid 提交的字段校验通过
    if book_ser.is_valid():
    book_ser.save()
    response['book'] = book_ser.data
    else:
    response['msg'] = book_ser.errors # errors 是序列化类 中的钩子函数 raise来的报错信息
    return Response(response) """修改功能"""
    def put(self, request, id):
    response = {'status': 100, 'msg': '修改成功'}
    if id: # 提交的字典
    book = request.data
    # 传统方法,创建对象保存
    print(book)
    book_obj = models.Book.objects.filter(pk=id).first() # 新方法,通过序列化组件保存,必须继承自ModelSerializer
    book_ser = BookSerializer(data=book, instance=book_obj)
    # is_valid 提交的字段校验通过
    if book_ser.is_valid():
    # 这里save()做修改
    book_ser.save()
    response['book'] = book_ser.data
    else:
    response['msg'] = book_ser.errors
    else:
    response['msg'] = '修改对象不存在'
    return Response(response) """删除功能"""
    def delete(self, request, id):
    models.Book.objects.filter(pk=id).delete()
    response = {'status': 100, 'msg': '删除成功'}
    return Response(response) from django.core.exceptions import ObjectDoesNotExist
    import uuid """用户登录类"""
    class Login(APIView):
    # 局部禁用认证组件
    authentication_classes = []
    # 局部禁用权限组件
    permission_classes = []
    # 局部禁用频率组件
    throttle_classes = [] def post(self, request):
    response = {'code': 100, 'msg': '登录成功'}
    name = request.data.get('name')
    pwd = request.data.get('pwd')
    print(name, pwd)
    try:
    # get()方法,获取 有且只有一条的 才不报错,其他情况都抛异常
    ret = models.User.objects.filter(name=name, pwd=pwd).get() # 登录成功后要去token 表中去存数据
    # 表里有 数据或没有数据
    # 1. 先生成随机字符串 用uuid
    token = uuid.uuid4()
    # 2. 存入token表
    # update_or_create() 方法 先查后改,查到就修改,没查到就新增 根据 user 去查
    models.Token.objects.update_or_create(user=ret, defaults={'token': token})
    response['token'] = token
    except ObjectDoesNotExist as exc:
    response['code'] = 101
    response['msg'] = '用户名或密码错误'
    except Exception as e:
    response['code'] = 102
    response['msg'] = str(e)
    return Response(response)
    • 全局使用:在settings文件中配置 DEFAULT_THROTTLE_CLASSES
    # 全局使用认证、权限组件、频率组件
    REST_FRAMEWORK = {
    # 全局认证组件配置
    "DEFAULT_AUTHENTICATION_CLASSES": ["app01.auths.MyAuth", ],
    # 全局权限组件配置
    "DEFAULT_PERMISSION_CLASSES": ["app01.permissions.MyPermission", ],
    # 频率组件全局配置
    'DEFAULT_THROTTLE_CLASSES': ['app01.throttles.RateThrottle', ],
    # 控制访问频率为一分钟三次
    'DEFAULT_THROTTLE_RATES': {
    'qzk': '3/m' # 这里的'qzk' 是根据频率校验类中的scope决定的,两者保持一致
    } #
    }
    • 局部禁用:在需要禁用的视图类中 将配置的throttle_classes = [ ] 置空
    class Book(APIView):
    """局部使用三个认证、权限、频率"""
    # 局部禁用认证校验组件
    authentication_classes = []
    # 局部禁用权限校验组件
    permission_classes = []
    # 局部禁用频率校验组件
    throttle_classes = []

补充models.py

from django.db import models

# Create your models here.

class Book(models.Model):
title = models.CharField(max_length=32)
price = models.DecimalField(max_digits=8, decimal_places=2)
publish_time = models.DateTimeField(auto_now_add=True) # 自动添加创建时间
authors = models.ManyToManyField('Author')
publish = models.ForeignKey('Publish') # 一对多 def test(self):
return self.title + '>>' + str(self.price) class Author(models.Model):
name = models.CharField(max_length=32)
age = models.IntegerField()
authordetail = models.OneToOneField('AuthorDetail') class AuthorDetail(models.Model):
tel_num = models.BigIntegerField()
addr = models.CharField(max_length=32) class Publish(models.Model):
name = models.CharField(max_length=32)
addr = models.CharField(max_length=32)
email = models.EmailField() class User(models.Model):
name = models.CharField(max_length=32)
pwd = models.CharField(max_length=32)
user_type = models.IntegerField(choices=((1, '超级用户'), (2, '普通用户'), (3, '游客')),default=3) class Token(models.Model):
user = models.OneToOneField(to='User')
token = models.CharField(max_length=64)

urls.py

from django.conf.urls import url
from django.contrib import admin
from app01 import views urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^books/(?P<id>\d*)',views.Book.as_view()),
url(r'^login/',views.Login.as_view())
]

Django 之 restframework 频率组件的使用的更多相关文章

  1. rest-framework频率组件、url注册器、响应器、分页器

    频率组件 import time from rest_framework.throttling import BaseThrottle,SimpleRateThrottle IP_DICT = {} ...

  2. rest-framework频率组件

    throttle(访问频率)组件 1.局部视图throttle from rest_framework.throttling import BaseThrottle VISIT_RECORD={} c ...

  3. rest-framework框架——认证、权限、频率组件

    一.rest-framework登录验证 1.models.py添加User和Token模型 class User(models.Model): name = models.CharField(max ...

  4. Django的rest_framework的权限组件和频率组件源码分析

    前言: Django的rest_framework一共有三大组件,分别为认证组件:perform_authentication,权限组件:check_permissions,频率组件:check_th ...

  5. 基于Django的Rest Framework框架的频率组件

    0|1一.频率组件的作用 在我们平常浏览网站的时候会发现,一个功能你点击很多次后,系统会让你休息会在点击,这其实就是频率控制,主要作用是限制你在一定时间内提交请求的次数,减少服务器的压力. modle ...

  6. Django框架深入了解_03(DRF之认证组件、权限组件、频率组件、token)

    一.认证组件 使用方法: ①写一个认证类,新建文件:my_examine.py # 导入需要继承的基类BaseAuthentication from rest_framework.authentica ...

  7. Django day28 频率组件,解析器

    一:频率组件: 1.频率是什么? 节流,访问控制 2. (1)内置的访问频率控制类SimpleRateThrottle (2)写一个类,继承SimpleRateThrottle class MyThr ...

  8. Django框架之DRF 认证组件源码分析、权限组件源码分析、频率组件源码分析

    认证组件 权限组件 频率组件

  9. RestFramework之频率组件

    一.频率组件的使用 频率组件的存在对我们这web开发有着很大的影像,它的作用就是限制用户在一段时间内访问的次数. 下面让我们介绍一下频率组件怎样使用 1.首先需要导入 from rest_framew ...

随机推荐

  1. Linux上安装git并在gitlab上建立对应的项目

    1.CentOS上面安装git我所用的CentOS为CentOS6.5,其他版本没有测试. yum install git 安装之后查看git版本信息 git --version 2.配置git信息g ...

  2. springboot修改页面不用重启的设置(idea)

       1) “File” -> “Settings” -> “Build,Execution,Deplyment” -> “Compiler”,选中打勾 “Build project ...

  3. 解决docker容器日志导致主机磁盘空间满了的情况

    日志文件在   /var/lib/docker/containers/<docker_container_id>/   目录下 查看日志大小 vim /opt/docker_log_siz ...

  4. 深度学习 NI-DL 框架

    NI-DL 应用框架:图像分类,目标检测,分割提取. 底层:TensorFlow,Keras,Cuda,C/C++ 上层:C#.NET Winform [图像分类] 识别一张图片是否为某个类型的物体/ ...

  5. ssh密码登录+ Google Authenticator 实现双向认证

    通常我们直接通过ssh输入密码连接服务器,但这样很容易出现暴力破解情况,所以我们可以结合google的动态认证+ssh密码,这样能够大大的提升登陆的安全. 简单来说,就是当用户通过ssh登陆系统时,先 ...

  6. ASP.NET-------gridview 进行编辑的时候,给出提示

    在使用gridview 控件的时候,控制修改人的操作行为,并给出合理的提示, 比如 在执行编辑操作的时候  不允许姓名为空,并显示出提示,姓名不可以为空 操作: 前台页面,对一些字段的解释 一定要注意 ...

  7. iphone如何安装mitmproxy的pem文件(当iphone无法使用邮箱时)

    背景描述: 我要安装mitmproxy描述文件 mitmproxy-ca-cert.pem , 说是用iphone自带的邮箱接收然后安装即可,但悲剧的邮箱坏了[提示:无法连接服务器],查了不少方法都无 ...

  8. centOS 在线安装lnmp

    CentOS7源码安装最新版LNMP环境   lnmp环境版本如下: 系统:CentOS 7 x86_64 NGINX:nginx-1.7.12 数据库:mariadb-10.0.13 PHP:php ...

  9. AD常用快捷键

    元器件翻转 : 空格 按住shift拖动元器件实现自动编号 取消布线 : 工具(Tools)取消布线(Un_Route)全部(AII) 栅格变为点阵 : 按ctrl+G——打开cartesian Gr ...

  10. 原生js数值开根算法

    不借助Math函数求开根值 1.二分迭代法求n开根后的值 思路: left=0 right=n mid=(left+right)/2 比较mid^2与n大小 =输出: >改变范围,right=m ...