이전 게시물을 통해 서버를 준비했으므로
애플리케이션을 생성해보겠습니다.
아직 서버 준비가 안 된 분들은 아래 게시글을 통해 준비하세요.
2020/09/15 - [IT/Python] - [Django] 장고 시작 - 장고 설치 및 프로젝트 생성
새 폴더 - nameapp 생성
아래 명령으로 루트에 있는 test_server 아래에 새 폴더 nameapp이 생성되었습니다.
python manage.py startapp nameapp
다음과 같은 트리 구조를 갖는 새 폴더 nameapp이 생성됩니다.
명령어를 통해 확인이 가능합니다.
추가 설정
다음과 같은 명령어를 통해 REST 프레임워크를 설치합니다.
pip install djangorestframework
다음과 같은 명령어를 통해 Swagger를 설치합니다.
pip install django-rest-swagger
settings.py 파일을 열어 설치된 프레임워크 관련 설정을 추가합니다.
[REST 프레임워크: 장고 앱의 REST API 통신을 지원]
[REST 프레임워크 스웨거: REST API 관리를 위한 웹 사용자 인터페이스]
'rest_framework',
'rest_framework_swagger',
'nameapp'
test_server 폴더에 templates 폴더와 static 폴더를 추가합니다.
settings.py에 HTML 코드를 저장할 templates 관련 설정을 추가합니다.
'DIRS': [os.path.join(BASE_DIR, 'templates')],
웹 사이트를 꾸미기 위한 CSS, JS 파일을 가져올 수 있도록 설정하는 부분을
DATABASES 윗 부분에 추가합니다.
import os
.
.
.
MEDIA_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'
STATICFILES_DIRS = ( os.path.join(BASE_DIR, "static"), )
MEDIA_URL = ''
STATIC_ROOT = ''
다음으로 디버깅 용도의 로깅을 위한 로그 메시지 저장 파일을 설정합니다.
logging 라이브러리를 사용하여 다음과 같이 코드를 추가하여 설정합니다.
test_server.log 파일에 logging라이브러리를 통해 출력한 로그 메시지를 저장합니다.
import logging
.
.
.
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
'standard': {
'format': '%(asctime)s %(levelname)s %(name)s %(message)s'
},
},
'handlers': {
'default': {
'level':'DEBUG',
'class':'logging.handlers.RotatingFileHandler',
'filename': 'test_server.log',
'maxBytes': 1024*1024*5, # 5 MB
'backupCount': 5,
'formatter':'standard',
},
},
'loggers': {
'': {
'handlers': ['default'],
'level': 'DEBUG',
'propagate': True
},
}
}
이렇게 설정을 마친 settings.py 파일의 전체 코드 내용은 다음과 같습니다.
"""
Django settings for test_server project.
Generated by 'django-admin startproject' using Django 3.1.1.
For more information on this file, see
https://docs.djangoproject.com/en/3.1/topics/settings/
For the full list of settings and their values, see
https://docs.djangoproject.com/en/3.1/ref/settings/
"""
from pathlib import Path
import os
import logging
# Build paths inside the project like this: BASE_DIR / 'subdir'.
BASE_DIR = Path(__file__).resolve().parent.parent
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/3.1/howto/deployment/checklist/
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': {
'standard': {
'format': '%(asctime)s %(levelname)s %(name)s %(message)s'
},
},
'handlers': {
'default': {
'level':'DEBUG',
'class':'logging.handlers.RotatingFileHandler',
'filename': 'test_server.log',
'maxBytes': 1024*1024*5, # 5 MB
'backupCount': 5,
'formatter':'standard',
},
},
'loggers': {
'': {
'handlers': ['default'],
'level': 'DEBUG',
'propagate': True
},
}
}
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '&kuh90m#=r2%%x8_3%=1fb#d%0n3s62fu@!xeye4s@_z&-e(11'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'rest_framework_swagger',
'nameapp'
]
MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
]
ROOT_URLCONF = 'test_server.urls'
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
WSGI_APPLICATION = 'test_server.wsgi.application'
MEDIA_ROOT = os.path.join(BASE_DIR, 'static')
STATIC_URL = '/static/'
STATICFILES_DIRS = ( os.path.join(BASE_DIR, "static"), )
MEDIA_URL = ''
STATIC_ROOT = ''
# Database
# https://docs.djangoproject.com/en/3.1/ref/settings/#databases
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': BASE_DIR / 'db.sqlite3',
}
}
# Password validation
# https://docs.djangoproject.com/en/3.1/ref/settings/#auth-password-validators
AUTH_PASSWORD_VALIDATORS = [
{
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
},
{
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
},
]
# Internationalization
# https://docs.djangoproject.com/en/3.1/topics/i18n/
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/3.1/howto/static-files/
STATIC_URL = '/static/'
'Back end > Django' 카테고리의 다른 글
[Django] 이메일 주소록 관리 앱 개발하기 (0) | 2020.09.29 |
---|---|
[Django] 장고 시작 - 장고 설치 및 프로젝트 생성 (2) | 2020.09.15 |