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.面向过程编程 ...
随机推荐
- IIS部署ASP.Net Core 502.5错误和解决
在Win7的机器上部署ASP.Net Core程序,老是提示502.5错误. 已经安装了 Microsoft Visual C++ 2015 Redistributable .NET Core Win ...
- UVA 10118 Free Candies
https://vjudge.net/problem/UVA-10118 题目 桌上有4堆糖果,每堆有$N$($N\leqslant 40$)颗.有个熊孩子拿了个可以装5颗糖的篮子,开始玩无聊的装糖游 ...
- python之常用模块二(hashlib logging configparser)
摘要:hashlib ***** logging ***** configparser * 一.hashlib模块 Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 摘要算法 ...
- VS界面控件大小调整
vs2015 ,配置名称显示不全,怎么才能把这个搞宽? 这个问题困扰时间挺长了, 对vs的应用仅限于敲代码.编译, 其他的功能了解甚少, 于是试着在右键菜单中找到了界面自定义窗口, 如下: 找到想要修 ...
- 基于JavaCv并发读取本地视频流并提取每帧32位dhash特征
1.读取本地视频流,pom依赖 依赖于 org.bytedeco下的javacv/opencv/ffmpeg 包 <dependency> <groupId>org.byted ...
- Django Cookie,Session
Cookie Cookie的由来 HTTP协议是无状态的,每次请求都是独立的,对服务器来说,每次的请求都是全新的,上一次的访问是数 据是无法保留到下一次的 某些场景需要状态数据或者中间数据等相关对下一 ...
- <Android基础> (五) 广播机制
1)接收系统广播:a.动态注册监听网络变化 b.静态注册实现开机启动 2)发送自定义广播:a.发送标准广播 b.发送有序广播 3)使用本地广播 第五章 5.1 广播机制 Android中的每个程序都可 ...
- 关于win10企业版在极域电子教室软件 v4.0 2015 豪华版的全屏控制下如何取得自由
注.可能因为系统和软件的缘故无法实现 背景 由于在听课过程过于自闭,于是想自己去网上搜点东西看下 于是 经过了一番乱搞 逐渐摸索出了现方法. 方案1: 大力出奇迹 由于电脑在刚刚进入的状态的时候有段时 ...
- java String转int int转化为String
String转int String str = "123"; int a = Integer.parseInt(str); System.out.println(a); Integ ...
- Java基础知识拾遗(一)
类型提升规则 Java定义了几个应用于表达式的类型提升规则:所有byte.short和char类型的值都被提升为int类型.如果有一个操作数是long类型,将这个表达式提升为 long 类型:如果有一 ...