Django/restframework

DRF tutorial -2 requests and responses

두잇 두두 2024. 1. 2. 21:00
728x90

REST 프레임워크는 Request을 더욱 확장해서 사용합니다.

request.POST, request.GET이 아닌 하나의 클래스에서 처리하기를 지향하기 때문에 request.data를 사용 할 수 있습니다. 

request.POST  # Only handles form data.  Only works for 'POST' method.
request.data  # Handles arbitrary data.  Works for 'POST', 'PUT' and 'PATCH' methods.

 

API 뷰 래핑

DRF에서 API를 보기 좋게 작성하기 위해 두 가지 방법을 사용합니다.

1. @API_view 함수 기반 뷰 작업을 위한 데코레이터

2. APIView 클래스 기반 뷰로 작업하기 위한 클래스

from rest_framework import status
from rest_framework.decorators import api_view
from rest_framework.response import Response
from snippets.models import Snippet
from snippets.serializers import SnippetSerializer


@api_view(['GET', 'POST'])
def snippet_list(request):
    """
    List all code snippets, or create a new snippet.
    """
    if request.method == 'GET':
        snippets = Snippet.objects.all()
        serializer = SnippetSerializer(snippets, many=True)
        return Response(serializer.data)

    elif request.method == 'POST':
        serializer = SnippetSerializer(data=request.data)
        if serializer.is_valid():
            serializer.save()
            return Response(serializer.data, status=status.HTTP_201_CREATED)
        return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

위 snippet_list 함수에 @api_view 데코레이터를 추가해서 request 받는 요청을 GET과 POST로 제한하며 명시 해줍니다.

GET일 시 객체를 모두 보여주고 POST시 객체를 생성해주는 작업을 합니다

 

@api_view(['GET', 'PUT', 'DELETE'])
def snippet_detail(request, pk):
    """
    Retrieve, update or delete a code snippet.
    """
    try:
        snippet = Snippet.objects.get(pk=pk)
    except Snippet.DoesNotExist:
        return Response(status=status.HTTP_404_NOT_FOUND)

    if request.method == 'GET':
        serializer = SnippetSerializer(snippet)
        return Response(serializer.data)

    elif request.method == 'PUT':
        serializer = SnippetSerializer(snippet, data=request.data)
        if serializer.is_valid():
            serializer.save()
            return Response(serializer.data)
        return Response(serializer.errors, status=status.HTTP_400_BAD_REQUEST)

    elif request.method == 'DELETE':
        snippet.delete()
        return Response(status=status.HTTP_204_NO_CONTENT)

detail의 경우 처음 try,except로 해당 pk값을 지닌 객체가 있는지 확인 후 조회, 수정, 삭제 기능을 제공합니다

 

해당 튜토리얼 2에서는 Response시 status를 다루는 법에 대해 집중적으로 배웠습니다.