[Django][Django restframework] Django REST framework 시작하기

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

django 와 djangorestframework를 pip로 설치한다.

$ pip install django
$ pip install djangorestframework

tutorial라는 이름의 Django project를 생성하고, myapp이라는 이름의 앱을 생성한다.
프로젝트와 앱을 생성하는 방식이 Django REST framework Quickstart 과는 다르다. Django docs의 Django 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_name 과 last_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에 하나로 그룹화하여 간결하게 사용할 수 있다.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

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

[출처] https://cjh5414.github.io/django-rest-framework/

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
492 [Python 수학] Python/데이터 사이언스 [파이썬] Numpy 정리 졸리운_곰 2023.11.28 13
491 [python, C++] Interfacing C++ and Python with the Python API : C++ 및 Python과 Python API의 인터페이스 file 졸리운_곰 2023.08.18 29
490 [python 일반] 파이참 에러 : Fatal Python error: init_stdio_encoding: failed to get the Python codec name of the stdio encoding file 졸리운_곰 2023.07.06 15
489 (Python) Jupyter Notebook 내에서만 환경 변수 설정 방법 졸리운_곰 2023.07.06 14
488 [python] 인공지능 python : 한글 문서 자동 요약 - lexrank 졸리운_곰 2023.07.06 15
487 [Python] 문자열에서 파일명 또는 폴더명으로 시스템상 지원되는 글자를 제외하고 삭제하기 졸리운_곰 2023.06.04 24
486 [python 일반] 파이썬 win32com 사용시 에러 해결 file 졸리운_곰 2023.06.04 119
485 [python 일반] win32com.gen_py 라이브러리의 오류 해결 졸리운_곰 2023.06.03 26
484 [Python 일반] 파일(폴더) 이름에 사용할 수 없는 특수 문자 제거 졸리운_곰 2023.06.03 24
483 [Python 일반] 파이썬에서 재귀적으로 깊은 계층적 디렉토리를 생성하기 위한 makedirs 졸리운_곰 2023.06.03 24
482 [python] 인공지능 katiehouse / django-scikit-learn-tutorial file 졸리운_곰 2023.06.03 34
481 [python][자료구조] Python - MySQL 데이터 추가, 삭제, 업데이트 졸리운_곰 2023.05.13 27
480 [Python 인터넷] 네이버 뉴스 기사 크롤링 졸리운_곰 2023.05.13 35
» [Django][Django restframework] Django REST framework 시작하기 file 졸리운_곰 2023.05.07 7
478 [Django] REST API 로그인 서버 만들기 (2) - DB 연동, 테스트 file 졸리운_곰 2023.05.07 14
477 [Django] REST API 로그인 서버 만들기 (1) - 코드 졸리운_곰 2023.05.07 21
476 [Django] user의 ip address 가지고 오기 졸리운_곰 2023.05.07 13
475 [Django] [Python_Django] You are trying to add a non-nullable field '필드명' to post without a default 해결 졸리운_곰 2023.05.07 19
474 [Django] [Python_Django] 관리자 계정에서 테이블 관리하기 file 졸리운_곰 2023.05.06 8
473 [python][자료구조] Python의 JSON - 문자열을 JSON으로 변환하는 방법 졸리운_곰 2023.05.06 26
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED