장고 12)REST API_2

  • API
    • 응용 프로그래밍 인터페이스
    • 애플리케이션과 프로그래밍 방식으로 통신하는 방법
      • 개발자가 복잡한 기능을 쉽게 만들 수 있도록 프로그래밍 언어로 제공되는 컴퍼지션
    • API를 제공하는 애플리케이션과 다른 소프트웨어 및 하드웨어 간의 간단한 계약(인터페이스)으로 볼 수 있습니다.

    • API는 대신 사용할 수 있는 더 쉬운 구문을 제공하기 위해 복잡한 코드를 추상화합니다.

  • 웹 API
    • 웹 서버 또는 웹 브라우저용 API
    • 현재 웹 개발은 모든 것을 하나씩 개발하기보다는 여러 개방형 API를 활용하는 경향이 있습니다.

    • 대표적인 타사 개방형 API 서비스 목록
      • 유튜브 API
      • 네이버 파파고 API
      • 코코아 맵 API
    • API는 다양한 유형의 데이터로 응답합니다.

      • HTML, XML, JSON 등

나머지

  • 대표 상태 이전
  • API 서버 개발을 위한 일종의 소프트웨어 설계 방법론
  • 리소스를 정의하고 처리하는 전반적인 방법

REST API 사용해보기

# my_api/urls.py

from django.contrib import admin
from django.urls import path, include

urlpatterns = (
	path('admin/', admin.site.urls),
	path('api/v1/', include('articles.urls')),
)
# articles/urls.py

from django.urls import path
from . import views

urlpatterns = (
	path('html/', views.article_html),
	path('json-1/', views.article_json_1),
	path('json-2/', views.article_json_2),
	path('json-3/', views.article_json_3),
)

JsonResponse()를 사용한 JSON 응답

  • 하나의 문서(HTML)에 응답하는 대신 JSON 데이터에 응답해 보십시오.
  • Django에서 제공하는 JsonResponse 객체를 사용하면 Python 데이터 유형을 응답용 JSON으로 쉽게 변환할 수 있습니다.

# articles/views.py

from django.http.response import JsonResponse

def article_json_1(request):
	articles = Article.objects.all()
	articles_json = {}

	for article in articles:
		articles_json.append(
			{
				'id':article.pk,
				'title': article.title,
				'content': article.content,
				'created_at': article.created_at,
				'updated_at': article.updated_at,
			}
		)
	return JsonResponse(articles_json, safe=False)

Django Serializer를 사용한 JSON 응답

  • Django의 내장 HttpResponse()를 사용한 JSON 응답
  • JSON의 모든 필드를 수동으로 작성할 필요가 없습니다.

# articles/views.py

from django.http.response import JsonResponse, HttpResponse
from django.core import serializers

def article_json_2(request):
	articles = Article.objects.all()
	data = serializers.serialize('json', articles)
	return HttpResponse(data, content_type="application/json")

직렬화

  • “직렬화”
  • 데이터 구조 또는 개체 상태를 여러 시스템에서 사용하기 위해 나중에 재구성할 수 있는 형식으로 변환하는 프로세스
  • 대표 포맷: json, xml, yaml
  • Django의 serialize()는 Queryset 및 Model Instance와 같은 복잡한 데이터를 JSON 및 XML과 같은 유형으로 쉽게 변환할 수 있는 Python 데이터 유형으로 변환합니다.

Django REST 프레임워크를 사용한 JSON 응답

  • 장고 REST 프레임워크(DRF)
    • Django에서 Restful API 서버를 쉽게 구축할 수 있게 해주는 오픈 소스 라이브러리입니다.

    • 웹 API 구축을 위한 강력한 툴킷을 제공합니다.

    • 참조: www.django-rest-framework.org/
# settings.py

INSTALLED_APPS = (
	'...'
	'rest_framework',
	'...'
)
  • ModelForm과 유사한 ModelSerializer 구조 및 사용법 확인
# articles.serializers.py

from rest_framework import serializers
from .models import Article

class ArticleSerializer(serializers.ModelSerializer):
	class Meta:
		model = Article
		fields '__all__'
# articles/views.py

@api_view()
def article_json_3(request):
	articles = Article.objects.all()
	serializer = ArticleSerializer(articles, many=True)
	return Response(serializer.data)

Django REST 프레임워크 – 단일 모델

  • 우편 집배원
    • API 구축 및 사용을 위한 플랫폼
    • API를 빠르게 생성할 수 있는 여러 도구와 기능을 제공합니다.


장고 12)REST API_2 1

# urls.py

from django.urls import path
from articles import views

urlpatterns = (
	path('articles/', views.article_list),
)
  • DRF 설치, 등록 및 패키지 목록 업데이트
    • pip 설치 djangorestframework

ModelSerializer 작성

  • 기사/serializers.py 생성
    • serializers.py의 위치와 파일 이름은 자유롭게 작성할 수 있습니다.

  • ModelSerializer 작성
# articles/serializers.py

from rest_framework import serializers
from .models import Article

class ArticleListSerializer(serializers.ModelSerializer):
	class Meta:
		model = Article
		fields = ('id', 'title', 'content',)
  • ModelSerializer 클래스는 모델 필드에 해당하는 필드가 있는 Serializer 클래스를 자동으로 생성하는 바로 가기를 제공합니다.

    • 모델 정보에 따라 자동으로 필드 생성
    • 직렬 변환기용 유효성 검사기 자동 생성
    • .create() 및 .update()의 간단한 기본 구현을 포함합니다.

예) QuerySet 객체 직렬화

articles = Article.objects.all()

serializer = ArticleListSerializer(articles, many=True)
serializer.data
... # 데이터 출력됨

RESTful API 구축 – 기사


장고 12)REST API_2 2

GET – 목록

  • 게시물 데이터 목록 검색
  • DRF에 api_view 데코레이터를 작성하는 데 필요합니다.

# articles/urls.py

urlpatterns = (
	path('articles/', views.article_list),
)
# articles/views.py

from rest_framework.response import Response
from rest_framework.decorators import api_view

from.models import Article
from.serializer import ArticleListSerializer

# api_view 데코레이터를 통해 GET메서드만 허용. 
@api_view(('GET'))
def article_list(request):
	articles = Article.objects.all()
	serializer = ArticleListSerializer(articles, many=True)
	return Response(serializer.data)

GET – 세부 정보

  • 단일 게시물 데이터 검색
  • 각 데이터 조각의 세부 정보를 제공하는 ArticleSerializer 정의
# articles/serializers.py

class ArticleSerializer(serializers.ModelSerializer):
	class Meta:
		model = Article
		fields="__all__"
# articles/urls.py

urlpatterns = (
	...
	path('articles/<int:article_pk>/', views.article_detail),
)
# articles/views.py

from .serializers import ArticleListSerializer, ArticleSerializer

@api_view(('GET'))
def article_detail(request, article_pk):
	article = Article.objects.get(pk=article_pk)
	serializer = ArticleSerializer(article)
	return Response(serializer.data)