django-rest-framework
数据序列化/串行化:把对象处理成字符或者字节就叫序列化——比如数据模型映射到数据库、比如把对象模型处理成json数据
反序列化/反串行化:把字符或者字节还原成对象就叫反序列化——比如把数据库的一张表的某行数据还原成一个模型对象
json/pickle——json.dumps(xxx)是把xxx字符串化;pickle.dumps(xxx)是把xxx字节串化;
1、序列化(重点,三种方法查询数据)——serializer
2、数据持久化(数据库数据缓存至redis)——cache_page
3、限流(防止爬虫)——settings.py-REST_FRAMEWORK配置信息
4、数据分页——settings.py-REST_FRAMEWORK配置信息
1、序列化serializer
序列化模型对象有两种情况:
(1)FBV——function base view ——基于函数的视图
(2)CBV——class base view ——基于类的视图(推荐)
FBV:
访问路由配置信息:
urlpatterns = [
path('get_province/',views.get_province),
]
def get_provinces(request):
#parent__isnull=True——选择parent属性是空的对象;
queryset = District.objects.filter(parent__isnull=True).only('name')
#调用序列化器序列化实例对象,many=True-用于序列化多个对象时;
serializer = DistrictSerializer(queryset, many=True)
#返回json数据,safe=False-用于传回数据不是字典格式的数据;
return JsonResponse(serializer.data, safe=False)
#序列化器
class DistrictSerializer(serializers.ModelSerializer):
class Meta:
#要序列化的模型
model = District
#要序列化的对象属性或者字段
fields = ('distid', 'name')
CBV:
第一种
访问路由配置信息
urlpatterns = [
path('estates/', EstateView.as_view()),
]
from rest_framework.generics import ListAPIView, RetrieveAPIView
#RetrieveAPIView-支持单个对象查询,ListAPIView-支持多个对象查询
class EstateView(RetrieveAPIView,ListAPIView):
queryset = TbEstate.objects.all().select_related('distid')
serializer_class = EstateSerializer
#序列化器
class EstateSerializer(serializers.ModelSerializer):
#只读字段,该字段通过调用父序列化器类上的方法获得其表示形式。调用的方法将采用“get_(fieldnamel)”形式,并且应该接受单个参数,该参数是被序列化的对象。
district = serializers.SerializerMethodField()
@staticmethod
def get_district(self,estate):
#序列化TbEstate模型的对象,即estate。貌似用此方法来序列化外键对应的表属性。
return DistrictSerializer(estate.distid).data
class Meta:
model = TbEstate
fields = ('estateid', 'name', 'district', 'hot', 'intro')
===========================
第二种
访问路由配置信息
# 第二种CBV方法需要注册访问路由 并加入 urlpatterns
urlpatterns = []
router = DefaultRouter()
router.register('housetypes', views.HouseTypeViewSet)
urlpatterns += router.urls
from rest_framework_extensions.cache.mixins import CacheResponseMixin
#CacheResponseMixin--既支持单个对象又支持多个对象查询
class HouseTypeViewSet(CacheResponseMixin,ModelViewSet):
queryset = TbHouseType.objects.all()
serializer_class = HouseTypeSerializer
#序列化器
class HouseTypeSerializer(serializers.ModelSerializer):
class Meta:
model =TbHouseType
fields = "__all__"
2、数据持久化
把经常会使用到的数据,从数据库中查询出来,然后将其缓存在redis中,是常用的提高网站浏览性能的做法。
例如:
对下面FBV型的视图函数查询的数据,加上@cache_page()装饰器就可将查询的数据保存至对应的redis缓存中。
from django.views.decorators.cache import cache_page
#timeout-数据保存时间(s);cache-对应的缓存名称(缓存配置在项目setting.py文件中);key_profix-数据的键值key前缀,用来区分键值key相同的情况;
@cache_page(timeout=86400*365,cache='api',key_prefix='cities')
def get_city(request,pid):
queryset=TbDistrict.objects.filter(pid=pid).only('distid','name')
serializer=DistrictDetailSerializer(queryset,many=True)
return JsonResponse(serializer.data,safe=False)
对下面CBV型的视图函数查询的数据加入redis缓存中,需要单独在项目settings.py文件配置设置。
from rest_framework_extensions.cache.mixins import CacheResponseMixin
class HouseTypeViewSet(CacheResponseMixin,ModelViewSet):
queryset = TbHouseType.objects.all()
serializer_class = HouseTypeSerializer
# 第二种数据序列化HouseTypeViewSet 会调用此配置,因为其对象是CacheResponseMixin类
# 配置DRF扩展来支持缓存API接口调用结果
REST_FRAMEWORK_EXTENSIONS = {
'DEFAULT_CACHE_RESPONSE_TIMEOUT': 300,
'DEFAULT_USE_CACHE': 'api',
# 配置默认缓存单个对象的key函数
'DEFAULT_OBJECT_CACHE_KEY_FUNC': 'rest_framework_extensions.utils.default_object_cache_key_func',
# 配置默认缓存对象列表的key函数
'DEFAULT_LIST_CACHE_KEY_FUNC': 'rest_framework_extensions.utils.default_list_cache_key_func',
}
3、4限流、数据分页
项目settings.py文件配置情况
REST_FRAMEWORK = {
# 配置默认页面大小(数据几条)
'PAGE_SIZE': 5,
# 配置默认的分页
'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
# 配置默认限流类(防爬虫)
'DEFAULT_THROTTLE_CLASSES': (
'rest_framework.throttling.AnonRateThrottle', #限制匿名用户访问速率
'rest_framework.throttling.UserRateThrottle' #限制用户访问速率
),
'DEFAULT_THROTTLE_RATES': {
'anon': '3/min', #限制同一ip一分钟访问3次
'user': '10000/day' #限制同一ip一天访问10000次
},
}