python全栈开发day102-django rest-framework框架
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框架的更多相关文章
- Python全栈开发:django网络框架(二)
Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行 ...
- Python全栈开发:django网络框架(一)
Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM.模型绑定.模板引擎.缓存.Session等诸多功能. ...
- 巨蟒python全栈开发数据库前端8:jQuery框架2
数据可视化推荐网站(都是JavaScript写的): echart网站: https://echarts.baidu.com/ 聚宽网站: https://www.joinquant.com/ 我们要 ...
- 巨蟒python全栈开发数据库前端7:jQuery框架
每个人的标准不同,看法等等,认识,价值观有所不同,促成了这些矛盾. 1.select例子 <!DOCTYPE html> <html lang="en"> ...
- python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)
昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...
- python全栈开发目录
python全栈开发目录 Linux系列 python基础 前端~HTML~CSS~JavaScript~JQuery~Vue web框架们~Django~Flask~Tornado 数据库们~MyS ...
- Python全栈开发相关课程
Python全栈开发 Python入门 Python安装 Pycharm安装.激活.使用 Python基础 Python语法 Python数据类型 Python进阶 面向对象 网络编程 并发编程 数据 ...
- Python 全栈开发【第0篇】:目录
Python 全栈开发[第0篇]:目录 第一阶段:Python 开发入门 Python 全栈开发[第一篇]:计算机原理&Linux系统入门 Python 全栈开发[第二篇]:Python基 ...
- Python全栈开发【面向对象进阶】
Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...
- Python全栈开发【面向对象】
Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...
随机推荐
- Docker 容器日志格式化
Docker容器的日志文件每一行都是一个json对象,其包含log.stream.time三个属性,下面的HTML从textarea中读取输入的日志信息,格式化为表格显示. <!DOCTYPE ...
- Flask 模型操作
ORM 简称 ORM, O/RM, O/R Mapping 持久化模型 特征 数据表和编程类的映射 数据类型映射 字段属性映射类的属性和数据类型 关系映射 表于表之间的关系对应到 编程类的关系上 优点 ...
- 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
- 【CF1132F】Clear the String(动态规划)
[CF1132F]Clear the String(动态规划) 题面 CF 题解 考虑区间\(dp\). 增量考虑,每次考虑最后一个字符和谁一起删去,然后直接转移就行了. #include<io ...
- CSS实现动画特效导航栏
0 写在前面 今天用纯CSS编写了一种带有特效的导航栏,一方面巩固熟悉了导航栏的一般写法,另一方面练习了CSS3的一些新特性. 1 实现效果 当鼠标划过时,实现了一种动态百叶窗效果. 2 实现细节 2 ...
- adb调试
adb usb调试,adb网络调试是非常实用的工具,通过电脑连接手机达到文件传输.电脑端安装app刷机等功能材料: 材料: 1.电脑端安装号对应手机的驱动程序 2.电脑端下载好adb调试工具 3.手机 ...
- CentOS配置防火墙操作实例
CentOS 配置防火墙操作实例(启.停.开.闭端口): 注:防火墙的基本操作命令: 查询防火墙状态: [root@localhost ~]# service iptables status<回 ...
- npm install 之前做的事
在一个项目目录中,npm install之前,需要npm init,npm init会问你几个问题,有的需要输入,不想输入的一路回车就行,之后会自动创建一个package.json文件,有了这个pac ...
- React 记录(7)
React文档:https://www.reactjscn.com/docs/handling-events.html 慢慢学习:对照教程文档,逐句猜解,截图 React官网:https://reac ...
- SpringBoot系列: 制作Docker镜像的全过程
本文主要参考了 https://segmentfault.com/a/1190000016449865 , 感谢作者的付出. 另外, 在本文中, 演示了Windows+Maven+Docker To ...