Django REST framework 시작하기

Reading time ~4 minutes

Django에는 REST API를 만들 수 있는 Django REST framework가 존재한다. Django REST framework Quickstart 을 참고하여 tutorial을 진행해봤다. Django REST framework Quickstart에서는 Django tutorial과 다른 디렉토리 구조를 사용하고 django에 기본적으로 내장 되어있는 User, Group 에 대한 예제를 다룬다. 이와 다르게 이 포스트에서는 Django tutorial에서 사용하는 디렉토리 구조를 사용하고 새로운 앱과 모델을 생성하여 REST API를 생성하는 방법에 대해 작성하였다.


프로젝트 설정

django-rest-tutorial 이라는 Root 디렉토리를 생성한다.

$ mkdir django-rest-tutorial
$ cd django-rest-tutorial

python 3.5.2 버전으로 가상환경을 구축한다.

$ pyenv install 3.5.2
$ pyenv virtualenv 3.5.2 django-rest-tutorial
$ pyenv activate django-rest-tutorial

djangodjangorestframework를 pip로 설치한다.

$ pip install django
$ pip install djangorestframework

tutorial라는 이름의 Django project를 생성하고, myapp이라는 이름의 앱을 생성한다.
프로젝트와 앱을 생성하는 방식이 Django REST framework Quickstart 과는 다르다. Django docsDjango tutorial 01에서 사용하는 방식을 이용했다.

$ django-admin.py startproject tutorial
$ cd tutorial
$ python manage.py startapp myapp

Root 디렉토리의 프로젝트 구조를 보면 아래와 같다.

$ tree ../../django-rest-tutorial/
django-rest-tutorial/
└── tutorial
    ├── manage.py
    ├── myapp
    │   ├── __init__.py
    │   ├── admin.py
    │   ├── apps.py
    │   ├── migrations
    │   │   └── __init__.py
    │   ├── models.py
    │   ├── tests.py
    │   └── views.py
    └── tutorial
        ├── __init__.py
        ├── settings.py
        ├── urls.py
        └── wsgi.py


Settings

Django REST framework을 사용하기 위해서는 'rest_framework'를 INSTALL_APPS에 추가해줘야 한다.
pagination의 크기를 지정할 수 있고, API의 접근 권한을 지정할 수도 있다. 아래의 주석 처리된 부분을 사용하면 admin 사용자일 때만 접근이 가능하다.

tutorial/settings.py

INSTALLED_APPS = [
    ...
    'rest_framework',
    'myapp'
]

REST_FRAMEWORK = {
    'DEFAULT_PERMISSION_CLASSES': [
        # 'rest_framework.permissions.IsAdminUser',
    ],
    'PAGE_SIZE': 10
}


Models

first_namelast_name 필드를 가진 Person이라는 간단한 model을 정의하였다.

myapp/models.py

from django.db import models


class Person(models.Model):
    first_name = models.CharField(max_length=30)
    last_name = models.CharField(max_length=30)


Serializers

serializer란 models 객체와 querysets 같은 복잡한 데이터를 JSON, XML과 같은 native 데이터로 바꿔주는 역할을 한다. 아래에서는 HyperlinkedModelSerializer라는 serializer를 사용한다.

myapp/serializers.py

from myapp.models import Person
from rest_framework import serializers


class PersonSerializer(serializers.HyperlinkedModelSerializer):
    class Meta:
        model = Person
        fields = ('first_name', 'last_name')


Views

여러 개의 view를 작성하지 않고, 공통적인 행위들을 ViewSet에 하나로 그룹화하여 간결하게 사용할 수 있다.

myapp/views.py

from rest_framework import viewsets
from serializers import PersonSerializer
from myapp.models import Person


class PersonViewSet(viewsets.ModelViewSet):
    queryset = Person.objects.all()
    serializer_class = PersonSerializer


URLs

views에서 작성한 ViewSet을 Router에 연결하면 url을 자동으로 맵핑해주기 때문에 편리하게 이용할 수 있다.

tutorial/urls.py

from django.conf.urls import url, include
from rest_framework import routers
from myapp import views


router = routers.DefaultRouter()
router.register(r'persons', views.PersonViewSet)

urlpatterns = [
    url(r'^', include(router.urls)),
    url(r'^api-auth/', include('rest_framework.urls', namespace='rest_framework'))
]


Run

$ python manage.py makemigrations
$ python manage.py migrate
$ python manage.py runserver

우선 browser를 통해 http://localhost:8000에 접속해보면 DefaultRouter에 의해 사용할 수 있는 url http://localhost:8000/persons 이 표시된다.

result home

눌러보면 GET으로 요청이 돼서 아래와 같이 결과가 나오고,

request get

아래에 데이터를 입력하고 POST 버튼을 눌러서 요청하면,

input post data

요청될 POST request에 대한 정보가 표시되면서 요청이 된다.

request post

다시 오른쪽의 GET 버튼을 눌러서 요청을 해보면 POST로 요청했을 때 DB에 저장된 데이터를 불러와서 보여준다.

request get after post

Git remote branch 가져오기

Git을 사용하다보면 원격 저장소에 있는 branch를 로컬 저장소로 가져와야하는 경우가 있다. 협업하고 있는 다른 팀원의 branch를 가져와서 작업을 해야하는 경우 혹은 혼자서 2대의 PC를 사용하고 작업파일을 Git으로 관리하는데 bra...… Continue reading