1.频次访问组件

  1) 手写版本  

# class VisitThrottle(BaseThrottle):
#
# def __init__(self):
# self.history = None
#
# def allow_request(self, request, view):
# """
# 限制IP每分钟访问不能超过3次
# :param request:
# :param view:
# :return:
# """
#
# # 确定访问IP
# print(self.get_ident(request))
# remote_addr = request.META.get('REMOTE_ADDR')
# print("REMOTE_ADDR", remote_addr)
#
# # 获取当次访问时间
# ctime = time.time()
#
# # if 第一次访问
# if remote_addr not in VISIT_RECORD:
# VISIT_RECORD[remote_addr] = [ctime, ]
# return True
#
# history = VISIT_RECORD.get(remote_addr)
# self.history = history
#
# while history and ctime - history[-1] > 60:
# history.pop()
#
# if len(history) < 3:
# history.insert(0, ctime)
# return True
# else:
# return False
#
# def wait(self):
# # 当前访问时间
# ctime = time.time()
#
# # 访问时间历史记录 self.history
#
# return 60 - (ctime - self.history[-1])

频率访问组件

  2)rest-framework自带的简单组件

from rest_framework.throttling import SimpleRateThrottle

class VisitedThrottle(SimpleRateThrottle):
scope = 'visited_rate'
THROTTLE_RATES = {'visited_rate': '3/m'} def get_cache_key(self, request, view):
return self.get_ident(request) # 写在全局
settings.py
"DEFAULT_THROTTLE_CLASSES": ("app01.utils.throttle_class.VisitThrottle",),
"DEFAULT_THROTTLE_RATES": {
"visit_rate": "10/m",
},

simpleRateThrottle

2.URL解析器

用法:

产生4条url:

支持.json等格式访问:

3.分页

# 定义分页组件类
class MyPageNumberPagination(PageNumberPagination):
page_size = 2
page_query_param = 'p'
page_size_query_param = 'size'
max_page_size = 3 class BookView(APIView):
# parser_classes = [FormParser, JSONParser, MultiPartParser] def get(self, request):
book_list = Book.objects.all().order_by('pk')
mypagination = MyPageNumberPagination() # 分页
pagination_list = mypagination.paginate_queryset(book_list, request) # 分页
bs = BookSerializer(pagination_list, many=True)
return response.Response(bs.data) class PublishView(ModelViewSet):
authentication_classes = [UserAuth, ]
# throttle_classes = [UserThrottle, ] permission_classes = [UserPermission, ]
queryset = Publish.objects.all().order_by('pk') #分页
serializer_class = PublishSerializer
pagination_class = MyPageNumberPagination # 分页

  

4.响应器

REST_FRAMEWORK={

    'DEFAULT_PARSER_CLASSES': (
'rest_framework.parsers.JSONParser',
'rest_framework.parsers.FormParser',
), 'DEFAULT_AUTHENTICATION_CLASSES': (
'app01.utils.auth_class.UserAuth', ), 'DEFAULT_PERMISSION_CLASSES': (
'app01.utils.permission_class.SVIPPermission',
), "DEFAULT_THROTTLE_CLASSES": ("app01.utils.throttle_class.VisitThrottle",),
"DEFAULT_THROTTLE_RATES": {
"visit_rate": "10/m",
}, 'DEFAULT_RENDERER_CLASSES': (
'rest_framework.renderers.JSONRenderer',
#'rest_framework.renderers.BrowsableAPIRenderer',
),
# "PAGE_SIZE":3
}

5. 重写serialiazer中的create方法,解决配置列的报错问题read_only或write_only

  

class BookSerializer(serializers.ModelSerializer):

    publish_name=serializers.CharField(max_length=32,source="publish.name",read_only=True)
# publish_pk=serializers.CharField(max_length=32,source="publish.pk",read_only=True)
# 该字段get的时候显示,post的时候不会写入create方法
publish_info=serializers.SerializerMethodField(read_only=True)
authors_list=serializers.SerializerMethodField(read_only=True)
def get_authors_list(self,obj):
ret=[]
for i in obj.authors.all():
ret.append({"name":i.name,"pk":i.pk})
return ret def get_publish_info(self,obj): return {"name":obj.publish.name,"publish_pk":obj.publish.pk} def create(self, validated_data):pass class Meta:
model = Book
# fields=["title","price"]
fields = "__all__"
# 设置字段get的时候不显示,post的时候会写入create方法
extra_kwargs={"publish":{"write_only":True},"authors":{"write_only":True}}

重写write:

BookSerializer

class BookSerializer(serializers.ModelSerializer):
publish_info = serializers.SerializerMethodField(read_only=False)
authors_info = serializers.SerializerMethodField(read_only=False) def get_authors_info(self, obj):
temp = []
for i in obj.authors.all():
temp.append({
"author_pk": i.pk,
"author_name": i.name,
"author_email": i.email
})
return temp def get_publish_info(self, obj):
return {"publish_pk": obj.publish.pk,
"publish_name": obj.publish.name,
"publish_addr": obj.publish.address} class Meta:
model = Book
fields = "__all__"
# exclude = ["publish"]
extra_kwargs = {
"publish": {"read_only": True},
"authors": {"read_only": True}
} def create(self, validated_data):
my_validated_data = validated_data['owner'] authors_info = my_validated_data.pop('authors_info')
publish_info = my_validated_data.pop('publish_info')
my_validated_data['publish_id'] = publish_info.get('publish_pk')
authors_pk_list = []
for i in authors_info:
authors_pk_list.append(i.get('author_pk'))
self.instance = Book.objects.create(**my_validated_data)
self.instance.authors.set(authors_pk_list)
return self.instance

类BookSerializer

BookView /重点.要将非model中的字段通过save(owner=request.data传给validated_data)

class BookView(APIView):
# parser_classes = [FormParser, JSONParser, MultiPartParser] def get(self, request):
book_list = Book.objects.all().order_by('pk')
mypagination = MyPageNumberPagination()
pagination_list = mypagination.paginate_queryset(book_list, request)
bs = BookSerializer(pagination_list, many=True)
return response.Response(bs.data) def post(self, request):
serializer = BookSerializer(data=request.data) if serializer.is_valid(): serializer.save(owner=request.data)
# print(serializer.data) # 必须在save()方法之后
# {'id': 8, 'title': '第10本书', 'price': 12, 'publish': 1, 'authors': [1, 3]}
print(serializer.validated_data)
# OrderedDict([('title', '第10本书'), ('price', 12), ('publish', < Publish: 沙河出版社 >),
# ('authors', [ < Author: 下马哥 >, < Author: eva >])])
return response.Response(serializer.data)
else:
return response.Response(serializer.errors)

类BookView

https://www.cnblogs.com/yuanchenqi/articles/8719520.html

python全栈开发day102-django rest-framework框架的更多相关文章

  1. Python全栈开发:django网络框架(二)

    Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行 ...

  2. Python全栈开发:django网络框架(一)

    Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...

  3. 巨蟒python全栈开发数据库前端8:jQuery框架2

    数据可视化推荐网站(都是JavaScript写的): echart网站: https://echarts.baidu.com/ 聚宽网站: https://www.joinquant.com/ 我们要 ...

  4. 巨蟒python全栈开发数据库前端7:jQuery框架

    每个人的标准不同,看法等等,认识,价值观有所不同,促成了这些矛盾. 1.select例子 <!DOCTYPE html> <html lang="en"> ...

  5. python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)

    昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...

  6. python全栈开发目录

    python全栈开发目录 Linux系列 python基础 前端~HTML~CSS~JavaScript~JQuery~Vue web框架们~Django~Flask~Tornado 数据库们~MyS ...

  7. Python全栈开发相关课程

    Python全栈开发 Python入门 Python安装 Pycharm安装.激活.使用 Python基础 Python语法 Python数据类型 Python进阶 面向对象 网络编程 并发编程 数据 ...

  8. Python 全栈开发【第0篇】:目录

    Python 全栈开发[第0篇]:目录   第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...

  9. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  10. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

随机推荐

  1. Docker 容器日志格式化

    Docker容器的日志文件每一行都是一个json对象,其包含log.stream.time三个属性,下面的HTML从textarea中读取输入的日志信息,格式化为表格显示. <!DOCTYPE ...

  2. Flask 模型操作

    ORM 简称 ORM, O/RM, O/R Mapping 持久化模型 特征 数据表和编程类的映射 数据类型映射 字段属性映射类的属性和数据类型 关系映射 表于表之间的关系对应到 编程类的关系上 优点 ...

  3. PHP 5.6 中 Automatically populating $HTTP_RAW_POST_DATA is deprecated and will be removed in a future version

    解决方法 找到php.ini  文件, 把always_populate_raw_post_data  修改为-1 就行了. always_populate_raw_post_data=-1

  4. 【CF1132F】Clear the String(动态规划)

    [CF1132F]Clear the String(动态规划) 题面 CF 题解 考虑区间\(dp\). 增量考虑,每次考虑最后一个字符和谁一起删去,然后直接转移就行了. #include<io ...

  5. CSS实现动画特效导航栏

    0 写在前面 今天用纯CSS编写了一种带有特效的导航栏,一方面巩固熟悉了导航栏的一般写法,另一方面练习了CSS3的一些新特性. 1 实现效果 当鼠标划过时,实现了一种动态百叶窗效果. 2 实现细节 2 ...

  6. adb调试

    adb usb调试,adb网络调试是非常实用的工具,通过电脑连接手机达到文件传输.电脑端安装app刷机等功能材料: 材料: 1.电脑端安装号对应手机的驱动程序 2.电脑端下载好adb调试工具 3.手机 ...

  7. CentOS配置防火墙操作实例

    CentOS 配置防火墙操作实例(启.停.开.闭端口): 注:防火墙的基本操作命令: 查询防火墙状态: [root@localhost ~]# service iptables status<回 ...

  8. npm install 之前做的事

    在一个项目目录中,npm install之前,需要npm init,npm init会问你几个问题,有的需要输入,不想输入的一路回车就行,之后会自动创建一个package.json文件,有了这个pac ...

  9. React 记录(7)

    React文档:https://www.reactjscn.com/docs/handling-events.html 慢慢学习:对照教程文档,逐句猜解,截图 React官网:https://reac ...

  10. SpringBoot系列: 制作Docker镜像的全过程

    本文主要参考了 https://segmentfault.com/a/1190000016449865 , 感谢作者的付出. 另外,  在本文中, 演示了Windows+Maven+Docker To ...