Django Filter Backend

前端 未结 5 1512
面向向阳花
面向向阳花 2021-01-11 18:03

I\'m working with Django rest framework API, I am trying to make a filter by first_name or by last_name or by both of them. This is my ContactViewSet.py :

5条回答
  •  滥情空心
    2021-01-11 18:53

    What I do, is write custom FilterBackend. Something like this:

    # views.py
    from rest_framework import filters
    
    class ObjektFilterBackend(filters.BaseFilterBackend):
        allowed_fields = ['objekt', 'naziv', 'kategorija', 'zadnja_sprememba']
    
        def filter_queryset(self, request, queryset, view):
            flt = {}
            for param in request.query_params:
                for fld in self.allowed_fields:
                    if param.startswith(fld):
                        flt[param] = request.query_params[param]
    
            return queryset.filter(**flt)
    
    
    class ObjektiViewSet(mixins.ListModelMixin,
                     mixins.RetrieveModelMixin,
                     viewsets.GenericViewSet):
        authentication_classes = (
            authentication.TokenAuthentication,
            authentication.SessionAuthentication)
        permission_classes = (IsAuthenticated,)
        queryset = models.Objekt.objects.all()
        serializer_class = serializers.ObjektSerializer
        filter_backends = (ObjektFilterBackend, ObjektOrderBackend,)
        ....
    

    Besides basic filtering (fieldname=value pairs) I can use any Django queryset Field Lookups (__gt, __gte, __startswith,...) in my URLs like this:

    http://localhost:8000/api/v2/objekti/?naziv__startswith=Apartma&zadnja_sprememba__gte=2018-01-01
    

    And ObjektFilterBackend class could be easily adapted to support searching by pattern.

    Just a little warning - this approach is potentially dangerous, because it allows end user to filter also by foreign key field. Something like this also works:

    http://localhost:8000/api/v2/objekti/?kategorija__naziv__icontains=sobe
    

    So restrict allowed_fields carefully and not include foreign keys that could lead to related User model.

提交回复
热议问题