day6:django-rest-framework---数据序列化、持久化、限流、分页

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次
    },
}

你可能感兴趣的:(day6:django-rest-framework---数据序列化、持久化、限流、分页)