美文网首页Python
day6:django-rest-framework---数据序

day6:django-rest-framework---数据序

作者: ATM_shark | 来源:发表于2019-03-04 15:48 被阅读192次

    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---数据序

        本文链接:https://www.haomeiwen.com/subject/lzybuqtx.html