Django-퀵 가이드
Django는 빠른 개발과 깔끔하고 실용적인 디자인을 장려하는 고수준 Python 웹 프레임 워크입니다. Django를 사용하면 더 적은 코드로 더 나은 웹 앱을 빠르고 쉽게 빌드 할 수 있습니다.
Note − Django는 Django Software Foundation의 등록 상표이며 BSD 라이선스에 따라 사용이 허가되었습니다.
장고의 역사
2003 − Adrian Holovaty와 Simon Willison이 Lawrence Journal-World 신문의 내부 프로젝트로 시작했습니다.
2005 − 2005 년 7 월 출시되어 재즈 기타리스트 Django Reinhardt의 이름을 따서 Django라는 이름을지었습니다.
2005 − 트래픽이 많은 여러 사이트를 처리 할 수있을만큼 성숙합니다.
Current − Django는 이제 전 세계에 기여하는 오픈 소스 프로젝트입니다.
Django – 디자인 철학
Django는 다음과 같은 디자인 철학을 가지고 있습니다.
Loosely Coupled − Django는 스택의 각 요소를 다른 요소와 독립적으로 만드는 것을 목표로합니다.
Less Coding − 코드가 적기 때문에 빠르게 개발할 수 있습니다.
Don't Repeat Yourself (DRY) − 모든 것은 반복되는 것이 아니라 정확히 한 곳에서만 개발되어야합니다.
Fast Development − Django의 철학은 초고속 개발을 촉진하기 위해 최선을 다하는 것입니다.
Clean Design − Django는 자체 코드 전체에 걸쳐 깔끔한 디자인을 엄격하게 유지하며 최상의 웹 개발 관행을 쉽게 따를 수 있습니다.
장고의 장점
여기에 나열 할 수있는 Django 사용의 몇 가지 장점이 있습니다.
Object-Relational Mapping (ORM) Support− Django는 데이터 모델과 데이터베이스 엔진을 연결하고 MySQL, Oracle, Postgres 등을 포함한 대규모 데이터베이스 시스템을 지원합니다. Django는 Django-nonrel 포크를 통해 NoSQL 데이터베이스도 지원합니다. 현재 지원되는 유일한 NoSQL 데이터베이스는 MongoDB 및 Google 앱 엔진입니다.
Multilingual Support− Django는 내장 된 국제화 시스템을 통해 다국어 웹 사이트를 지원합니다. 따라서 여러 언어를 지원하는 웹 사이트를 개발할 수 있습니다.
Framework Support − Django는 Ajax, RSS, Caching 및 기타 다양한 프레임 워크를 기본적으로 지원합니다.
Administration GUI − Django는 관리 활동을 위해 바로 사용할 수있는 멋진 사용자 인터페이스를 제공합니다.
Development Environment − Django는 종단 간 애플리케이션 개발 및 테스트를 용이하게하기 위해 경량 웹 서버와 함께 제공됩니다.
이미 알고 있듯이 Django는 Python 웹 프레임 워크입니다. 그리고 대부분의 최신 프레임 워크와 마찬가지로 Django는 MVC 패턴을 지원합니다. 먼저 MVC (Model-View-Controller) 패턴이 무엇인지 살펴본 다음 MVT (Model-View-Template) 패턴에 대한 Django의 특이성을 살펴 보겠습니다.
MVC 패턴
UI (웹 또는 데스크톱)를 제공하는 애플리케이션에 대해 이야기 할 때 일반적으로 MVC 아키텍처에 대해 이야기합니다. 이름에서 알 수 있듯이 MVC 패턴은 모델,보기 및 컨트롤러의 세 가지 구성 요소를 기반으로합니다. 자세한 내용은 여기 에서 MVC 자습서를 확인하십시오 .
DJANGO MVC-MVT 패턴
MVT (Model-View-Template)는 MVC와 약간 다릅니다. 실제로 두 패턴의 주요 차이점은 Django 자체가 컨트롤러 부분 (모델과 뷰 간의 상호 작용을 제어하는 소프트웨어 코드)을 처리하여 템플릿을 남긴다는 것입니다. 템플릿은 Django 템플릿 언어 (DTL)와 혼합 된 HTML 파일입니다.
다음 다이어그램은 MVT 패턴의 각 구성 요소가 서로 상호 작용하여 사용자 요청을 처리하는 방법을 보여줍니다.
개발자는 모델, 뷰 및 템플릿을 제공 한 다음 URL에 매핑하고 Django는 사용자에게 제공하는 마법을 수행합니다.
Django 개발 환경은 Python, Django 및 데이터베이스 시스템의 설치 및 설정으로 구성됩니다. Django는 웹 애플리케이션을 다루기 때문에 웹 서버 설정도 필요하다는 점을 언급 할 가치가 있습니다.
1 단계 – Python 설치
Django는 100 % 순수 Python 코드로 작성되었으므로 시스템에 Python을 설치해야합니다. 최신 Django 버전은 2.6.x 브랜치의 경우 Python 2.6.5 이상, 2.7.x 브랜치의 경우 2.7.3 이상이 필요합니다.
최신 Linux 또는 Mac OS X 배포 중 하나를 사용하는 경우 이미 Python이 설치되어있을 것입니다. 명령 프롬프트에서 python 명령을 입력하여 확인할 수 있습니다 . 이와 같은 것이 보이면 Python이 설치된 것입니다.
$ python
Python 2.7.5 (default, Jun 17 2014, 18:11:42)
[GCC 4.8.2 20140120 (Red Hat 4.8.2-16)] on linux2
그렇지 않으면 링크에서 최신 버전의 Python을 다운로드하여 설치할 수 있습니다. http://www.python.org/download.
2 단계-Django 설치
Django를 설치하는 것은 매우 쉽지만 설치에 필요한 단계는 운영 체제에 따라 다릅니다. Python은 플랫폼에 독립적 인 언어이므로 Django에는 운영 체제에 관계없이 모든 곳에서 작동하는 하나의 패키지가 있습니다.
링크에서 최신 버전의 Django를 다운로드 할 수 있습니다. http://www.djangoproject.com/download.
UNIX / Linux 및 Mac OS X 설치
Linux 또는 Mac OS 시스템을 실행하는 경우 Django를 설치하는 두 가지 방법이 있습니다.
OS의 패키지 관리자를 사용하거나 설치된 경우 easy_install 또는 pip를 사용할 수 있습니다.
이전에 다운로드 한 공식 아카이브를 사용하여 수동으로 설치하십시오.
첫 번째 옵션은 OS 배포에 따라 다르므로 두 번째 옵션을 다룰 것입니다. 첫 번째 옵션을 따르기로 결정했다면 설치할 Django 버전에주의하십시오.
위의 링크에서 아카이브를 받았다고 가정 해 보겠습니다. Django-x.xx.tar.gz와 같은 형식이어야합니다.
압축을 풀고 설치합니다.
$ tar xzvf Django-x.xx.tar.gz
$ cd Django-x.xx $ sudo python setup.py install
이 명령을 실행하여 설치를 테스트 할 수 있습니다.
$ django-admin.py --version
현재 버전의 Django가 화면에 인쇄되어 있으면 모든 것이 설정된 것입니다.
Note − 일부 Django 버전의 경우 django-admin이되고 ".py"가 제거됩니다.
Windows 설치
Django 아카이브와 Python이 컴퓨터에 설치되어 있다고 가정합니다.
먼저 PATH 확인입니다.
일부 Windows 버전 (Windows 7) C:\Python27\;C:\Python27\Lib\site-packages\django\bin\
에서는 물론 Python 버전에 따라 Path 시스템 변수에 다음 경로가 포함되어 있는지 확인해야 할 수 있습니다 .
그런 다음 Django를 추출하고 설치하십시오.
c:\>cd c:\Django-x.xx
다음으로 Windows 셸 "cmd"에서 관리자 권한이 필요한 다음 명령을 실행하여 Django를 설치합니다.
c:\Django-x.xx>python setup.py install
설치를 테스트하려면 명령 프롬프트를 열고 다음 명령을 입력하십시오.
c:\>django-admin.py --version
현재 버전의 Django가 화면에 인쇄되어 있으면 모든 것이 설정된 것입니다.
또는
"cmd"프롬프트를 시작하고 python을 입력 한 다음-
c:\> python
>>> import django
>>> print django.get_version()
3 단계 – 데이터베이스 설정
Django는 몇 가지 주요 데이터베이스 엔진을 지원하며 사용자의 편의에 따라 이들 중 하나를 설정할 수 있습니다.
- MySQL (http://www.mysql.com/)
- PostgreSQL (http://www.postgresql.org/)
- SQLite 3 (http://www.sqlite.org/)
- Oracle (http://www.oracle.com/)
- MongoDb (https://django-mongodb-engine.readthedocs.org)
- GoogleAppEngine Datastore (https://cloud.google.com/appengine/articles/django-nonrel)
선택한 데이터베이스를 설치하고 구성하는 방법은 각 설명서를 참조하십시오.
Note − 5 번과 6 번은 NoSQL 데이터베이스입니다.
4 단계 – 웹 서버
Django는 애플리케이션 개발 및 테스트를위한 경량 웹 서버와 함께 제공됩니다. 이 서버는 Django와 함께 작동하도록 미리 구성되어 있으며 더 중요한 것은 코드를 수정할 때마다 다시 시작된다는 것입니다.
그러나 Django는 Apache 및 Lighttpd와 같은 기타 인기있는 웹 서버를 지원합니다. 다른 예제로 작업하면서 다음 장에서 두 가지 접근 방식에 대해 논의 할 것입니다.
이제 Django를 설치 했으므로 사용을 시작하겠습니다. Django에서는 생성하려는 모든 웹 앱을 프로젝트라고합니다. 프로젝트는 응용 프로그램의 합계입니다. 애플리케이션은 MVT 패턴에 의존하는 코드 파일 세트입니다. 예를 들어 웹 사이트를 구축하고 싶다고 가정 해 보겠습니다. 웹 사이트는 프로젝트이고 포럼, 뉴스, 연락처 엔진은 애플리케이션입니다. 이 구조는 모든 응용 프로그램이 독립적이므로 프로젝트간에 응용 프로그램을 쉽게 이동할 수 있습니다.
프로젝트 생성
Windows이든 Linux이든 관계없이 터미널이나 cmd 프롬프트하고 프로젝트를 만들려는 위치로 이동 한 다음이 코드를 사용하십시오.
$ django-admin startproject myproject
다음과 같은 구조의 "myproject"폴더가 생성됩니다.
myproject/
manage.py
myproject/
__init__.py
settings.py
urls.py
wsgi.py
프로젝트 구조
"myproject"폴더는 프로젝트 컨테이너 일 뿐이며 실제로 두 가지 요소를 포함합니다.
manage.py−이 파일은 명령 줄을 통해 프로젝트와 상호 작용하기위한 프로젝트 로컬 django-admin의 일종입니다 (개발 서버 시작, db 동기화 ...). manage.py를 통해 액세스 할 수있는 전체 명령 목록을 얻으려면 코드를 사용할 수 있습니다.
$ python manage.py help
The “myproject” subfolder−이 폴더는 프로젝트의 실제 파이썬 패키지입니다. 그것은 네 개의 파일을 포함합니다-
__init__.py − 파이썬의 경우이 폴더를 패키지로 취급하십시오.
settings.py − 이름에서 알 수 있듯이 프로젝트 설정.
urls.py− 프로젝트 및 호출 할 함수의 모든 링크. 프로젝트의 일종의 ToC입니다.
wsgi.py − WSGI를 통해 프로젝트를 배포해야하는 경우.
프로젝트 설정
프로젝트는 myproject / settings.py 하위 폴더에 설정됩니다. 다음은 설정해야 할 몇 가지 중요한 옵션입니다.
DEBUG = True
이 옵션을 사용하면 프로젝트가 디버그 모드인지 여부를 설정할 수 있습니다. 디버그 모드를 사용하면 프로젝트 오류에 대한 자세한 정보를 얻을 수 있습니다. 라이브 프로젝트의 경우 'True'로 설정하지 마십시오. 그러나 Django 라이트 서버가 정적 파일을 제공하려면 'True'로 설정해야합니다. 개발 모드에서만 수행하십시오.
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3',
'NAME': 'database.sql',
'USER': '',
'PASSWORD': '',
'HOST': '',
'PORT': '',
}
}
데이터베이스는 '데이터베이스'사전에 설정되어 있습니다. 위의 예는 SQLite 엔진 용입니다. 앞서 언급했듯이 Django는 다음을 지원합니다.
- MySQL (django.db.backends.mysql)
- PostGreSQL (django.db.backends.postgresql_psycopg2)
- Oracle (django.db.backends.oracle) 및 NoSQL DB
- MongoDB (django_mongodb_engine)
새 엔진을 설정하기 전에 올바른 db 드라이버가 설치되어 있는지 확인하십시오.
TIME_ZONE, LANGUAGE_CODE, TEMPLATE…과 같은 다른 옵션을 설정할 수도 있습니다.
이제 프로젝트가 생성되고 구성되었으므로 작동하는지 확인하십시오.
$ python manage.py runserver
위의 코드를 실행하면 다음과 같은 결과가 나타납니다.
Validating models...
0 errors found
September 03, 2015 - 11:41:50
Django version 1.6.11, using settings 'myproject.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.
프로젝트는 많은 응용 프로그램의 합계입니다. 모든 응용 프로그램에는 목표가 있으며 웹 사이트의 문의 양식이 응용 프로그램이 될 수 있고 다른 사람에게 재사용 될 수있는 것처럼 다른 프로젝트에 재사용 될 수 있습니다. 프로젝트의 모듈로보십시오.
응용 프로그램 만들기
프로젝트 폴더에 있다고 가정합니다. 우리의 메인“myproject”폴더에서, 같은 폴더가 manage.py-
$ python manage.py startapp myapp
방금 myapp 응용 프로그램을 만들었고 프로젝트처럼 Django는 응용 프로그램 구조로 "myapp"폴더를 만듭니다.
myapp/
__init__.py
admin.py
models.py
tests.py
views.py
__init__.py − 파이썬이이 폴더를 패키지로 처리하도록합니다.
admin.py −이 파일은 관리자 인터페이스에서 앱을 수정할 수 있도록 도와줍니다.
models.py − 여기에는 모든 애플리케이션 모델이 저장됩니다.
tests.py − 이것은 단위 테스트가있는 곳입니다.
views.py − 여기에 애플리케이션보기가 있습니다.
프로젝트에 응용 프로그램에 대해 알기
이 단계에서 "myapp"애플리케이션이 생겼으므로 이제 Django 프로젝트 "myproject"에 등록해야합니다. 그렇게하려면 프로젝트의 settings.py 파일에서 INSTALLED_APPS 튜플을 업데이트하십시오 (앱 이름 추가)-
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'myapp',
)
Django는 관리 활동을 위해 바로 사용할 수있는 사용자 인터페이스를 제공합니다. 우리 모두는 웹 프로젝트에서 관리 인터페이스가 얼마나 중요한지 알고 있습니다. Django는 프로젝트 모델을 기반으로 관리 UI를 자동으로 생성합니다.
관리 인터페이스 시작
Admin 인터페이스는 django.countrib 모듈에 따라 다릅니다. 작동하게하려면 myproject / settings.py 파일의 INSTALLED_APPS 및 MIDDLEWARE_CLASSES 튜플에서 일부 모듈을 가져 왔는지 확인해야합니다.
INSTALLED_APPS의 경우 다음을 확인하십시오.
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'myapp',
)
MIDDLEWARE_CLASSES의 경우 −
MIDDLEWARE_CLASSES = (
'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',
)
서버를 시작하기 전에 관리자 인터페이스에 액세스하려면 데이터베이스를 시작해야합니다.
$ python manage.py migrate
syncdb는 관리자 인터페이스를 실행하는 데 필요한 db 유형에 따라 필요한 테이블 또는 컬렉션을 만듭니다. 수퍼 유저가 없더라도 생성하라는 메시지가 표시됩니다.
이미 수퍼 유저가 있거나 잊어 버린 경우 다음 코드를 사용하여 언제든지 만들 수 있습니다.
$ python manage.py createsuperuser
이제 관리 인터페이스를 시작하려면 관리 인터페이스에 대한 URL을 구성했는지 확인해야합니다. myproject / url.py를 열고 다음과 같은 것이 있어야합니다.
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'myproject.views.home', name = 'home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
)
이제 서버를 실행하십시오.
$ python manage.py runserver
관리자 인터페이스는 http://127.0.0.1:8000/admin/에서 액세스 할 수 있습니다.
수퍼 유저 계정에 연결되면 다음 화면이 표시됩니다.
이 인터페이스를 사용하면 Django 그룹과 사용자, 앱에 등록 된 모든 모델을 관리 할 수 있습니다. 인터페이스는 모델에서 최소한 "CRUD"(생성, 읽기, 업데이트, 삭제) 작업을 수행 할 수있는 기능을 제공합니다.
보기 함수 또는 줄여서 "view"는 웹 요청을 받아 웹 응답을 반환하는 Python 함수입니다. 이 응답은 웹 페이지의 HTML 콘텐츠, 리디렉션, 404 오류, XML 문서 또는 이미지 등이 될 수 있습니다. 예 :보기를 사용하여 웹 페이지를 만들려면보기를 연결해야합니다. URL에 연결하여 웹 페이지로 볼 수 있습니다.
Django에서는 앱 views.py 파일에서 뷰를 생성해야합니다.
간단한보기
myapp에 "welcome to my app!"이라는 간단한보기를 생성합니다.
다음보기를 참조하십시오-
from django.http import HttpResponse
def hello(request):
text = """<h1>welcome to my app !</h1>"""
return HttpResponse(text)
이 뷰에서는 HttpResponse를 사용하여 HTML을 렌더링합니다 (보기에 HTML이 하드 코딩되어 있음을 알 수 있듯이). 이 뷰를 페이지로 보려면 URL에 매핑하기 만하면됩니다 (다음 장에서 설명합니다).
이전에 뷰에서 HTML을 렌더링하기 위해 HttpResponse를 사용했습니다. 이것은 페이지를 렌더링하는 가장 좋은 방법이 아닙니다. Django는 MVT 패턴을 지원하므로 Django-MVT와 같은 선례보기를 만들려면 다음이 필요합니다.
템플릿 : myapp / templates / hello.html
이제 우리의 견해는 다음과 같습니다.
from django.shortcuts import render
def hello(request):
return render(request, "myapp/template/hello.html", {})
뷰는 또한 매개 변수를 받아 들일 수 있습니다-
from django.http import HttpResponse
def hello(request, number):
text = "<h1>welcome to my app number %s!</h1>"% number
return HttpResponse(text)
URL에 연결되면 페이지에 매개 변수로 전달 된 번호가 표시됩니다. 매개 변수는 URL을 통해 전달됩니다 (다음 장에서 설명).
이제 이전 장에서 설명한 작업 뷰가 생겼습니다. URL을 통해 해당 뷰에 액세스하려고합니다. Django는 URL 매핑을위한 자체 방법이 있으며 프로젝트 url.py 파일을 편집하여 수행됩니다.(myproject/url.py). url.py 파일은 다음과 같습니다.
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
#Examples
#url(r'^$', 'myproject.view.home', name = 'home'),
#url(r'^blog/', include('blog.urls')),
url(r'^admin', include(admin.site.urls)),
)
사용자가 웹 앱에서 페이지를 요청하면 Django 컨트롤러가 url.py 파일을 통해 해당 뷰를 찾은 다음 HTML 응답 또는 찾을 수없는 경우 404 찾을 수 없음 오류를 반환합니다. url.py에서 가장 중요한 것은"urlpatterns"튜플. URL과보기 간의 매핑을 정의하는 곳입니다. 매핑은 다음과 같은 URL 패턴의 튜플입니다.
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
#Examples
#url(r'^$', 'myproject.view.home', name = 'home'),
#url(r'^blog/', include('blog.urls')),
url(r'^admin', include(admin.site.urls)),
url(r'^hello/', 'myapp.views.hello', name = 'hello'),
)
표시된 줄은 URL "/ home"을 myapp / view.py 파일에 생성 된 hello보기에 매핑합니다. 위에서 볼 수 있듯이 매핑은 세 가지 요소로 구성됩니다.
The pattern− 확인하고 매핑하려는 URL과 일치하는 정규 표현식. python 're'모듈과 함께 작동 할 수있는 모든 것이 패턴에 적합합니다 (URL을 통해 매개 변수를 전달하려는 경우 유용함).
The python path to the view − 모듈을 가져올 때와 동일합니다.
The name− URL 반전을 수행하려면 위의 예 에서처럼 명명 된 URL 패턴을 사용해야합니다. 완료되면 서버를 시작하여 : http : //127.0.0.1/hello를 통해 뷰에 액세스하십시오.
URL 구성
지금까지 "myprojects / url.py"파일에 URL을 만들었지 만 Django 및 앱 만들기에 대해 앞서 언급했듯이 가장 좋은 점은 다른 프로젝트에서 응용 프로그램을 재사용 할 수 있다는 것입니다. 모든 URL을“projecturl.py”파일에 저장하면 문제가 무엇인지 쉽게 알 수 있습니다. 따라서 가장 좋은 방법은 애플리케이션별로 "url.py"를 만들고이를 주요 프로젝트 url.py 파일에 포함하는 것입니다 (이전에 관리자 인터페이스에 대한 관리 URL을 포함했습니다).
어떻게 되나요?
다음 코드를 사용하여 myapp에서 url.py 파일을 만들어야합니다.
from django.conf.urls import patterns, include, url
urlpatterns = patterns('', url(r'^hello/', 'myapp.views.hello', name = 'hello'),)
그런 다음 myproject / url.py는 다음과 같이 변경됩니다.
from django.conf.urls import patterns, include, url
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
#Examples
#url(r'^$', 'myproject.view.home', name = 'home'),
#url(r'^blog/', include('blog.urls')),
url(r'^admin', include(admin.site.urls)),
url(r'^myapp/', include('myapp.urls')),
)
myapp 애플리케이션의 모든 URL을 포함했습니다. "/ hello"를 통해 액세스 한 home.html은 이제 "/ myapp / hello"가되었으며 이는 웹 앱에 대해 더 좋고 이해하기 쉬운 구조입니다.
이제 myapp "morning"에 또 다른 뷰가 있고 myapp / url.py에 매핑하고 싶다고 가정 해 봅시다. 그런 다음 myapp / url.py를 다음과 같이 변경합니다.
from django.conf.urls import patterns, include, url
urlpatterns = patterns('',
url(r'^hello/', 'myapp.views.hello', name = 'hello'),
url(r'^morning/', 'myapp.views.morning', name = 'morning'),
)
이것은 리팩토링 될 수 있습니다-
from django.conf.urls import patterns, include, url
urlpatterns = patterns('myapp.views',
url(r'^hello/', 'hello', name = 'hello'),
url(r'^morning/', 'morning', name = 'morning'),)
보시다시피, 이제 첫 번째 요소를 사용합니다. urlpatterns튜플. 이는 앱 이름을 변경하려는 경우 유용 할 수 있습니다.
보기에 매개 변수 보내기
이제 URL을 매핑하는 방법, 구성하는 방법을 알았으므로 이제 매개 변수를 뷰에 보내는 방법을 살펴 보겠습니다. 고전적인 샘플은 기사 예제입니다 ( "/ articles / article_id"를 통해 기사에 액세스하려는 경우).
매개 변수 전달은 regexpURL 패턴에서. “myapp / view.py”에 다음과 같은 뷰가있는 경우
from django.shortcuts import render
from django.http import HttpResponse
def hello(request):
return render(request, "hello.html", {})
def viewArticle(request, articleId):
text = "Displaying article Number : %s"%articleId
return HttpResponse(text)
myapp / url.py에 매핑하여 "/ myapp / article / articleId"를 통해 액세스 할 수 있도록하고 싶습니다. "myapp / url.py"에 다음이 필요합니다.
from django.conf.urls import patterns, include, url
urlpatterns = patterns('myapp.views',
url(r'^hello/', 'hello', name = 'hello'),
url(r'^morning/', 'morning', name = 'morning'),
url(r'^article/(\d+)/', 'viewArticle', name = 'article'),)
Django가 url :“/ myapp / article / 42”를 볼 때 그것은 매개 변수 '42'를 viewArticle보기에 전달하고 브라우저에서 다음과 같은 결과를 얻을 것입니다.
여기서 매개 변수의 순서가 중요합니다. 1 년 중 한 달의 기사 목록을 원한다고 가정하고 viewArticles보기를 추가해 보겠습니다. 우리의 view.py는-
from django.shortcuts import render
from django.http import HttpResponse
def hello(request):
return render(request, "hello.html", {})
def viewArticle(request, articleId):
text = "Displaying article Number : %s"%articleId
return HttpResponse(text)
def viewArticles(request, month, year):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text)
해당 url.py 파일은 다음과 같습니다.
from django.conf.urls import patterns, include, url
urlpatterns = patterns('myapp.views',
url(r'^hello/', 'hello', name = 'hello'),
url(r'^morning/', 'morning', name = 'morning'),
url(r'^article/(\d+)/', 'viewArticle', name = 'article'),
url(r'^articles/(\d{2})/(\d{4})', 'viewArticles', name = 'articles'),)
이제 "/ myapp / articles / 12 / 2006 /"로 이동하면 'Displaying article of : 2006/12'가 표시되지만 매개 변수를 반전하면 동일한 결과를 얻지 못합니다.
이를 방지하기 위해 URL 매개 변수를보기 매개 변수에 링크 할 수 있습니다. 이를 위해url.py 될 것입니다-
from django.conf.urls import patterns, include, url
urlpatterns = patterns('myapp.views',
url(r'^hello/', 'hello', name = 'hello'),
url(r'^morning/', 'morning', name = 'morning'),
url(r'^article/(\d+)/', 'viewArticle', name = 'article'),
url(r'^articles/(?P\d{2})/(?P\d{4})', 'viewArticles', name = 'articles'),)
Django를 사용하면 python과 HTML을 분리 할 수 있으며, python은 뷰로 이동하고 HTML은 템플릿으로 이동합니다. 둘을 연결하기 위해 Django는 렌더링 함수와 Django 템플릿 언어에 의존합니다.
렌더 기능
이 함수는 세 가지 매개 변수를 취합니다.
Request − 초기 요청.
The path to the template − 이것은 프로젝트 settings.py 변수의 TEMPLATE_DIRS 옵션에 상대적인 경로입니다.
Dictionary of parameters− 템플릿에 필요한 모든 변수를 포함하는 사전. 이 변수를 만들거나 locals ()를 사용하여 뷰에 선언 된 모든 지역 변수를 전달할 수 있습니다.
Django 템플릿 언어 (DTL)
Django의 템플릿 엔진은 응용 프로그램의 사용자 대면 계층을 정의하는 미니 언어를 제공합니다.
변수 표시
변수는 다음과 같습니다. {{variable}}. 템플릿은 render 함수의 세 번째 매개 변수에서 뷰가 보낸 변수로 변수를 대체합니다. 오늘 날짜를 표시하도록 hello.html을 변경해 보겠습니다.
hello.html
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
</body>
</html>
그러면 우리의 견해는-
def hello(request):
today = datetime.datetime.now().date()
return render(request, "hello.html", {"today" : today})
이제 URL / myapp / hello에 액세스 한 후 다음 출력을 얻습니다.
Hello World!!!
Today is Sept. 11, 2015
이미 알고 있듯이 변수가 문자열이 아니면 Django는 __str__ 메서드를 사용하여 표시합니다. 그리고 같은 원리로 파이썬에서하는 것처럼 객체 속성에 접근 할 수 있습니다. 예 : 날짜 연도를 표시하려면 내 변수는 {{today.year}}입니다.
필터
표시 시간에 변수를 수정하는 데 도움이됩니다. 필터 구조는 다음과 같습니다. {{var | filters}}.
Some examples −
{{string|truncatewords:80}} −이 필터는 문자열을 자르므로 처음 80 개 단어 만 표시됩니다.
{{string|lower}} − 문자열을 소문자로 변환합니다.
{{string|escape|linebreaks}} − 문자열 내용을 이스케이프 한 다음 줄 바꿈을 태그로 변환합니다.
변수의 기본값을 설정할 수도 있습니다.
태그
태그를 사용하면 if 조건, for 루프, 템플릿 상속 등의 작업을 수행 할 수 있습니다.
경우 태그
Python에서와 마찬가지로 템플릿에서 if, else 및 elif를 사용할 수 있습니다.
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
</body>
</html>
이 새 템플릿에서는 날짜에 따라 템플릿이 특정 값을 렌더링합니다.
태그
'if'와 마찬가지로 Python과 똑같이 작동하는 'for'태그가 있습니다. 템플릿에 목록을 전송하도록 hello보기를 변경해 보겠습니다.
def hello(request):
today = datetime.datetime.now().date()
daysOfWeek = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
return render(request, "hello.html", {"today" : today, "days_of_week" : daysOfWeek})
{{for}}를 사용하여 해당 목록을 표시하는 템플릿 −
<html>
<body>
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
</body>
</html>
그리고 우리는 다음과 같은 것을 얻어야합니다.
Hello World!!!
Today is Sept. 11, 2015
We are I don't know.
Mon
Tue
Wed
Thu
Fri
Sat
Sun
태그 차단 및 확장
템플릿 상속 없이는 템플릿 시스템을 완성 할 수 없습니다. 즉, 템플릿을 디자인 할 때 페이지에 선택한 탭에 대한 특수 CSS가 필요할 수있는 것처럼 자녀의 템플릿이 자신의 필요에 따라 채울 구멍이있는 기본 템플릿이 있어야합니다.
hello.html 템플릿을 main_template.html에서 상속하도록 변경해 보겠습니다.
main_template.html
<html>
<head>
<title>
{% block title %}Page Title{% endblock %}
</title>
</head>
<body>
{% block content %}
Body content
{% endblock %}
</body>
</html>
hello.html
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
위의 예에서 / myapp / hello를 호출하면 이전과 동일한 결과를 얻을 수 있지만 이제 코드를 리팩토링하기 위해 extends 및 block에 의존합니다.
main_template.html에서 태그 블록을 사용하여 블록을 정의합니다. 제목 블록에는 페이지 제목이 포함되고 콘텐츠 블록에는 페이지 기본 콘텐츠가 포함됩니다. home.html에서 extends를 사용하여 main_template.html에서 상속 한 다음 위에서 정의한 블록 (내용 및 제목)을 채 웁니다.
댓글 태그
주석 태그는 HTML 주석이 아닌 템플릿에 주석을 정의하는 데 도움이되며 HTML 페이지에는 표시되지 않습니다. 문서화하거나 코드 줄에 주석을 달 때 유용 할 수 있습니다.
모델은 DB에서 테이블 또는 컬렉션을 나타내는 클래스이며 클래스의 모든 속성은 테이블 또는 컬렉션의 필드입니다. 모델은 app / models.py에 정의되어 있습니다 (예 : myapp / models.py).
모델 생성
다음은 예를 들어 만든 Dreamreal 모델입니다.
from django.db import models
class Dreamreal(models.Model):
website = models.CharField(max_length = 50)
mail = models.CharField(max_length = 50)
name = models.CharField(max_length = 50)
phonenumber = models.IntegerField()
class Meta:
db_table = "dreamreal"
모든 모델은 django.db.models.Model에서 상속됩니다.
우리 클래스에는 4 개의 속성 (3 개의 CharField 및 1 개의 Integer)이 있으며, 이들은 테이블 필드가됩니다.
db_table 속성이있는 Meta 클래스를 사용하면 실제 테이블 또는 컬렉션 이름을 정의 할 수 있습니다. Django는 테이블 또는 컬렉션의 이름을 자동으로 myapp_modelName으로 지정합니다. 이 클래스를 사용하면 테이블 이름을 원하는대로 강제 지정할 수 있습니다.
django.db.models에는 더 많은 필드 유형이 있습니다. https://docs.djangoproject.com/en/1.5/ref/models/fields/#field-types
모델을 만든 후 실제 데이터베이스를 생성하려면 Django가 필요합니다.
$python manage.py syncdb
데이터 조작 (CRUD)
모델에서 CRUD 작업을 수행 할 수있는 방법을보기 위해 "crudops"보기를 만들어 보겠습니다. myapp / views.py는 다음과 같습니다.
myapp/views.py
from myapp.models import Dreamreal
from django.http import HttpResponse
def crudops(request):
#Creating an entry
dreamreal = Dreamreal(
website = "www.polo.com", mail = "[email protected]",
name = "sorex", phonenumber = "002376970"
)
dreamreal.save()
#Read ALL entries
objects = Dreamreal.objects.all()
res ='Printing all Dreamreal entries in the DB : <br>'
for elt in objects:
res += elt.name+"<br>"
#Read a specific entry:
sorex = Dreamreal.objects.get(name = "sorex")
res += 'Printing One entry <br>'
res += sorex.name
#Delete an entry
res += '<br> Deleting an entry <br>'
sorex.delete()
#Update
dreamreal = Dreamreal(
website = "www.polo.com", mail = "[email protected]",
name = "sorex", phonenumber = "002376970"
)
dreamreal.save()
res += 'Updating entry<br>'
dreamreal = Dreamreal.objects.get(name = 'sorex')
dreamreal.name = 'thierry'
dreamreal.save()
return HttpResponse(res)
기타 데이터 조작
모델에서 할 수있는 다른 조작을 살펴 보겠습니다. CRUD 작업은 모델의 인스턴스에서 수행되었으므로 이제 모델을 나타내는 클래스로 직접 작업 할 것입니다.
'데이터 조작'뷰를 생성 해 보겠습니다. myapp/views.py
from myapp.models import Dreamreal
from django.http import HttpResponse
def datamanipulation(request):
res = ''
#Filtering data:
qs = Dreamreal.objects.filter(name = "paul")
res += "Found : %s results<br>"%len(qs)
#Ordering results
qs = Dreamreal.objects.order_by("name")
for elt in qs:
res += elt.name + '<br>'
return HttpResponse(res)
모델 연결
Django ORM은 모델을 연결하는 3 가지 방법을 제공합니다.
여기서 보게 될 첫 번째 사례 중 하나는 일대 다 관계입니다. 위의 예에서 볼 수 있듯이 Dreamreal 회사는 여러 온라인 웹 사이트를 가질 수 있습니다. 그 관계를 정의하는 것은 django.db.models.ForeignKey를 사용하여 이루어집니다-
myapp/models.py
from django.db import models
class Dreamreal(models.Model):
website = models.CharField(max_length = 50)
mail = models.CharField(max_length = 50)
name = models.CharField(max_length = 50)
phonenumber = models.IntegerField()
online = models.ForeignKey('Online', default = 1)
class Meta:
db_table = "dreamreal"
class Online(models.Model):
domain = models.CharField(max_length = 30)
class Meta:
db_table = "online"
업데이트 된 myapp / models.py에서 볼 수 있듯이 온라인 모델을 추가하고 Dreamreal 모델에 연결했습니다.
이 모든 것이 manage.py 셸을 통해 어떻게 작동하는지 확인해 보겠습니다.
먼저 Django 셸에서 테스트 할 회사 (Dreamreal 항목)를 생성 해 보겠습니다.
$python manage.py shell
>>> from myapp.models import Dreamreal, Online
>>> dr1 = Dreamreal()
>>> dr1.website = 'company1.com'
>>> dr1.name = 'company1'
>>> dr1.mail = 'contact@company1'
>>> dr1.phonenumber = '12345'
>>> dr1.save()
>>> dr2 = Dreamreal()
>>> dr1.website = 'company2.com'
>>> dr2.website = 'company2.com'
>>> dr2.name = 'company2'
>>> dr2.mail = 'contact@company2'
>>> dr2.phonenumber = '56789'
>>> dr2.save()
이제 일부 호스팅 된 도메인-
>>> on1 = Online()
>>> on1.company = dr1
>>> on1.domain = "site1.com"
>>> on2 = Online()
>>> on2.company = dr1
>>> on2.domain = "site2.com"
>>> on3 = Online()
>>> on3.domain = "site3.com"
>>> dr2 = Dreamreal.objects.all()[2]
>>> on3.company = dr2
>>> on1.save()
>>> on2.save()
>>> on3.save()
온라인 도메인에서 호스팅 회사 (Dreamreal 항목)의 속성에 액세스하는 것은 간단합니다.
>>> on1.company.name
Dreamreal의 회사에서 호스팅하는 모든 온라인 도메인을 알고 싶다면 코드를 사용합니다.
>>> dr1.online_set.all()
QuerySet을 얻으려면 이전에 본 모든 조작 방법 (filter, all, exclude, order_by ....)
또한 필터링 작업을 위해 링크 된 모델 속성에 액세스 할 수 있습니다. Dreamreal 이름에 'company'가 포함 된 모든 온라인 도메인을 가져오고 싶다고 가정 해 보겠습니다.
>>> Online.objects.filter(company__name__contains = 'company'
Note− 이러한 쿼리는 SQL DB에서만 지원됩니다. 조인이 존재하지 않고 두 개의 '_'가있는 비 관계형 DB에서는 작동하지 않습니다.
그러나 이것이 모델을 연결하는 유일한 방법은 아닙니다. 두 개체 간의 관계가 고유함을 보장하는 링크 인 OneToOneField도 있습니다. 위의 예에서 OneToOneField를 사용했다면 모든 Dreamreal 항목에 대해 하나의 온라인 항목 만 가능하고 반대로는 가능합니다.
마지막으로 테이블 간 (nn) 관계에 대한 ManyToManyField입니다. SQL 기반 DB와 관련이 있습니다.
웹 응용 프로그램에서는 여러 가지 이유로 페이지 리디렉션이 필요합니다. 특정 작업이 발생하거나 기본적으로 오류가 발생하는 경우 사용자를 다른 페이지로 리디렉션 할 수 있습니다. 예를 들어 사용자가 귀하의 웹 사이트에 로그인하면 종종 기본 홈 페이지 또는 개인 대시 보드로 리디렉션됩니다. Django에서 리디렉션은 'redirect'메서드를 사용하여 수행됩니다.
'redirect'메소드는 인수로 사용됩니다. 문자열 A보기의 이름으로 리디렉션 될 URL입니다.
myapp / views는 지금까지 다음과 같습니다.
def hello(request):
today = datetime.datetime.now().date()
daysOfWeek = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
return render(request, "hello.html", {"today" : today, "days_of_week" : daysOfWeek})
def viewArticle(request, articleId):
""" A view that display an article based on his ID"""
text = "Displaying article Number : %s" %articleId
return HttpResponse(text)
def viewArticles(request, year, month):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text)
hello 뷰를 djangoproject.com으로 리디렉션하고 viewArticle을 내부 '/ myapp / articles'로 리디렉션하도록 변경해 보겠습니다. 이를 위해 myapp / view.py는 다음과 같이 변경됩니다.
from django.shortcuts import render, redirect
from django.http import HttpResponse
import datetime
# Create your views here.
def hello(request):
today = datetime.datetime.now().date()
daysOfWeek = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
return redirect("https://www.djangoproject.com")
def viewArticle(request, articleId):
""" A view that display an article based on his ID"""
text = "Displaying article Number : %s" %articleId
return redirect(viewArticles, year = "2045", month = "02")
def viewArticles(request, year, month):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text)
위의 예에서 먼저 django.shortcuts에서 리디렉션을 가져 왔고 Django 공식 웹 사이트로 리디렉션하려면 전체 URL을 'redirect'메서드에 문자열로 전달하고 두 번째 예제 (viewArticle 뷰)에서는 'redirect'를 전달합니다. 메소드는 뷰 이름과 그의 매개 변수를 인수로받습니다.
/ myapp / hello에 액세스하면 다음 화면이 표시됩니다.
그리고 / myapp / article / 42에 액세스하면 다음 화면이 표시됩니다.
영구 = True 매개 변수를 추가하여 '리디렉션'이 임시인지 영구인지 여부를 지정할 수도 있습니다. 사용자에게는 차이가 없지만 웹 사이트 순위를 매길 때 검색 엔진이 고려하는 세부 정보입니다.
또한 URL을 매핑하는 동안 url.py에서 정의한 'name'매개 변수를 기억하십시오.
url(r'^articles/(?P\d{2})/(?P\d{4})/', 'viewArticles', name = 'articles'),
그 이름 (여기 기사)은 '리디렉션'메소드의 인수로 사용할 수 있으며, viewArticle 리디렉션은 다음과 같이 변경할 수 있습니다.
def viewArticle(request, articleId):
""" A view that display an article based on his ID"""
text = "Displaying article Number : %s" %articleId
return redirect(viewArticles, year = "2045", month = "02")
To −
def viewArticle(request, articleId):
""" A view that display an article based on his ID"""
text = "Displaying article Number : %s" %articleId
return redirect(articles, year = "2045", month = "02")
Note− URL을 생성하는 기능도 있습니다. 리디렉션과 동일한 방식으로 사용됩니다. 'reverse'메소드 (django.core.urlresolvers.reverse). 이 함수는 HttpResponseRedirect 개체를 반환하지 않고 전달 된 인수로 컴파일 된 뷰에 대한 URL이 포함 된 문자열을 반환합니다.
Django는 이메일을 보내기 위해 준비되고 사용하기 쉬운 라이트 엔진과 함께 제공됩니다. Python과 유사하게 smtplib를 가져 오기만하면됩니다. Django에서는 django.core.mail을 가져 오기만하면됩니다. 이메일 보내기를 시작하려면 프로젝트 settings.py 파일을 편집하고 다음 옵션을 설정하십시오.
EMAIL_HOST − smtp 서버.
EMAIL_HOST_USER − smtp 서버에 대한 로그인 자격 증명.
EMAIL_HOST_PASSWORD − smtp 서버의 암호 자격 증명.
EMAIL_PORT − smtp 서버 포트.
EMAIL_USE_TLS or _SSL − 보안 연결 인 경우 참.
간단한 이메일 보내기
간단한 전자 메일을 보내기 위해 "sendSimpleEmail"보기를 만들어 보겠습니다.
from django.core.mail import send_mail
from django.http import HttpResponse
def sendSimpleEmail(request,emailto):
res = send_mail("hello paul", "comment tu vas?", "[email protected]", [emailto])
return HttpResponse('%s'%res)
다음은 send_mail의 매개 변수에 대한 세부 사항입니다.
subject − 이메일 제목.
message − 이메일 본문.
from_email − 보낸 이메일.
recipient_list − 수신자의 이메일 주소 목록.
fail_silently − Bool, false이면 send_mail은 오류 발생시 예외를 발생시킵니다.
auth_user − settings.py에 설정되지 않은 경우 사용자 로그인.
auth_password − settings.py에 설정되지 않은 경우 사용자 비밀번호.
connection − 이메일 백엔드.
html_message − (Django 1.7의 새로운 기능) 존재하는 경우 이메일은 다중 부분 / 대안입니다.
뷰에 액세스 할 수있는 URL을 만들어 보겠습니다.
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^simpleemail/(?P<emailto>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/',
'sendSimpleEmail' , name = 'sendSimpleEmail'),)
따라서 /myapp/simpleemail/[email protected]에 액세스하면 다음 페이지가 표시됩니다.
send_mass_mail로 여러 메일 보내기
이 메서드는 성공적으로 전달 된 메시지 수를 반환합니다. 이것은 send_mail과 동일하지만 추가 매개 변수를 사용합니다. datatuple, sendMassEmail 뷰는 다음과 같습니다.
from django.core.mail import send_mass_mail
from django.http import HttpResponse
def sendMassEmail(request,emailto):
msg1 = ('subject 1', 'message 1', '[email protected]', [emailto1])
msg2 = ('subject 2', 'message 2', '[email protected]', [emailto2])
res = send_mass_mail((msg1, msg2), fail_silently = False)
return HttpResponse('%s'%res)
뷰에 액세스 할 수있는 URL을 만들어 보겠습니다.
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^massEmail/(?P<emailto1>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/(?P<emailto2>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})', 'sendMassEmail' , name = 'sendMassEmail'),)
/myapp/massemail/[email protected]/[email protected]/에 액세스하면-
send_mass_mail 매개 변수 세부 사항은 다음과 같습니다.
datatuples − 각 요소가 같은 튜플 (제목, 메시지, 보낸 사람 _ 이메일, 수신자 목록).
fail_silently − Bool, false이면 send_mail은 오류 발생시 예외를 발생시킵니다.
auth_user − settings.py에 설정되지 않은 경우 사용자 로그인.
auth_password − settings.py에 설정되지 않은 경우 사용자 비밀번호.
connection − 이메일 백엔드.
위 이미지에서 볼 수 있듯이 두 개의 메시지가 성공적으로 전송되었습니다.
Note −이 예에서는 Python smtp 디버깅 서버를 사용하고 있으며 다음을 사용하여 시작할 수 있습니다.
$python -m smtpd -n -c DebuggingServer localhost:1025
이것은 보낸 모든 이메일이 stdout에 인쇄되고 더미 서버가 localhost : 1025에서 실행 중임을 의미합니다.
Sending e-mails to admins and managers using mail_admins and mail_managers methods
이러한 메소드는 settings.py 파일의 ADMINS 옵션에 정의 된 사이트 관리자와 settings.py 파일의 MANAGERS 옵션에 정의 된 사이트 관리자에게 이메일을 보냅니다. ADMINS 및 MANAGERS 옵션이 다음과 같다고 가정 해 보겠습니다.
ADMINS = (( 'polo', '[email protected]'),)
MANAGERS = (( 'popoli', '[email protected]'),)
from django.core.mail import mail_admins
from django.http import HttpResponse
def sendAdminsEmail(request):
res = mail_admins('my subject', 'site is going down.')
return HttpResponse('%s'%res)
위의 코드는 ADMINS 섹션에 정의 된 모든 관리자에게 전자 메일을 보냅니다.
from django.core.mail import mail_managers
from django.http import HttpResponse
def sendManagersEmail(request):
res = mail_managers('my subject 2', 'Change date on the site.')
return HttpResponse('%s'%res)
위의 코드는 MANAGERS 섹션에 정의 된 모든 관리자에게 전자 메일을 보냅니다.
매개 변수 세부 사항-
Subject − 이메일 제목.
message − 이메일 본문.
fail_silently − Bool, false이면 send_mail은 오류 발생시 예외를 발생시킵니다.
connection − 이메일 백엔드.
html_message − (Django 1.7의 새로운 기능) 존재하는 경우 이메일은 다중 부분 / 대안입니다.
HTML 이메일 보내기
Django> = 1.7에서 HTML 메시지를 보내는 것은 다음과 같이 쉽습니다.
from django.core.mail import send_mail
from django.http import HttpResponse
res = send_mail("hello paul", "comment tu vas?", "[email protected]",
["[email protected]"], html_message=")
이것은 다중 파트 / 대체 이메일을 생성합니다.
그러나 Django <1.7의 경우 HTML 메시지를 보내는 것은 django.core.mail.EmailMessage 클래스를 통해 수행 된 다음 객체에서 'send'를 호출합니다.
HTML 전자 메일을 보내기 위해 "sendHTMLEmail"보기를 만들어 보겠습니다.
from django.core.mail import EmailMessage
from django.http import HttpResponse
def sendHTMLEmail(request , emailto):
html_content = "<strong>Comment tu vas?</strong>"
email = EmailMessage("my subject", html_content, "[email protected]", [emailto])
email.content_subtype = "html"
res = email.send()
return HttpResponse('%s'%res)
EmailMessage 클래스 생성을위한 매개 변수 세부 사항-
Subject − 이메일 제목.
message − HTML의 이메일 본문.
from_email − 보낸 이메일.
to − 수신자의 이메일 주소 목록.
bcc − "숨은 참조"수신자의 이메일 주소 목록.
connection − 이메일 백엔드.
뷰에 액세스 할 수있는 URL을 만들어 보겠습니다.
from django.conf.urls import patterns, url
urlpatterns = paterns('myapp.views', url(r'^htmlemail/(?P<emailto>
[\w.%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,4})/',
'sendHTMLEmail' , name = 'sendHTMLEmail'),)
/myapp/htmlemail/[email protected]에 접속하면-
첨부 파일이있는 이메일 보내기
이것은 EmailMessage 개체에서 'attach'메소드를 사용하여 수행됩니다.
첨부 파일이있는 이메일을 보내는보기는 다음과 같습니다.
from django.core.mail import EmailMessage
from django.http import HttpResponse
def sendEmailWithAttach(request, emailto):
html_content = "Comment tu vas?"
email = EmailMessage("my subject", html_content, "[email protected]", emailto])
email.content_subtype = "html"
fd = open('manage.py', 'r')
email.attach('manage.py', fd.read(), 'text/plain')
res = email.send()
return HttpResponse('%s'%res)
인수 첨부에 대한 세부 사항-
filename − 첨부 할 파일의 이름.
content − 첨부 할 파일의 내용.
mimetype − 첨부 파일의 콘텐츠 MIME 유형.
어떤 경우에는 앞에서 본 것처럼 뷰를 작성하는 것이 정말 무겁습니다. 정적 페이지 또는 목록 페이지가 필요하다고 가정 해보십시오. Django는 제네릭 뷰라는 간단한 뷰를 설정하는 쉬운 방법을 제공합니다.
클래식보기와 달리 일반보기는 함수가 아닌 클래스입니다. Django는 django.views.generic에서 제네릭 뷰에 대한 클래스 집합을 제공하며 모든 제네릭 뷰는 이러한 클래스 중 하나이거나 그 중 하나에서 상속되는 클래스입니다.
10 개 이상의 일반 클래스가 있습니다-
>>> import django.views.generic
>>> dir(django.views.generic)
['ArchiveIndexView', 'CreateView', 'DateDetailView', 'DayArchiveView',
'DeleteView', 'DetailView', 'FormView', 'GenericViewError', 'ListView',
'MonthArchiveView', 'RedirectView', 'TemplateView', 'TodayArchiveView',
'UpdateView', 'View', 'WeekArchiveView', 'YearArchiveView', '__builtins__',
'__doc__', '__file__', '__name__', '__package__', '__path__', 'base', 'dates',
'detail', 'edit', 'list']
일반보기에 사용할 수 있습니다. 어떻게 작동하는지 몇 가지 예를 살펴 보겠습니다.
정적 페이지
"static.html"템플릿에서 정적 페이지를 게시 해 보겠습니다.
우리 static.html-
<html>
<body>
This is a static page!!!
</body>
</html>
이전에 배운 방식으로 그렇게했다면 myapp/views.py ~로
from django.shortcuts import render
def static(request):
return render(request, 'static.html', {})
과 myapp/urls.py ~로
from django.conf.urls import patterns, url
urlpatterns = patterns("myapp.views", url(r'^static/', 'static', name = 'static'),)
가장 좋은 방법은 일반보기를 사용하는 것입니다. 이를 위해 myapp / views.py는-
from django.views.generic import TemplateView
class StaticView(TemplateView):
template_name = "static.html"
그리고 myapp / urls.py는 다음과 같습니다.
from myapp.views import StaticView
from django.conf.urls import patterns
urlpatterns = patterns("myapp.views", (r'^static/$', StaticView.as_view()),)
/ myapp / static에 액세스하면-
동일한 결과를 위해 다음을 수행 할 수도 있습니다.
- views.py에는 변경 사항이 없습니다.
- url.py 파일을 다음과 같이 변경하십시오.
from django.views.generic import TemplateView
from django.conf.urls import patterns, url
urlpatterns = patterns("myapp.views",
url(r'^static/',TemplateView.as_view(template_name = 'static.html')),)
보시다시피 두 번째 방법에서 url.py 파일을 변경하면됩니다.
DB에서 데이터 나열 및 표시
Dreamreal 모델의 모든 항목을 나열 할 것입니다. ListView 제네릭 뷰 클래스를 사용하면 쉽게 할 수 있습니다. url.py 파일을 편집하고 다음과 같이 업데이트하십시오.
from django.views.generic import ListView
from django.conf.urls import patterns, url
urlpatterns = patterns(
"myapp.views", url(r'^dreamreals/', ListView.as_view(model = Dreamreal,
template_name = "dreamreal_list.html")),
)
이 시점에서 중요한 점은 일반 뷰에서 템플릿으로 전달하는 변수가 object_list라는 것입니다. 직접 이름을 지정하려면 as_view 메소드에 context_object_name 인수를 추가해야합니다. 그러면 url.py는-
from django.views.generic import ListView
from django.conf.urls import patterns, url
urlpatterns = patterns("myapp.views",
url(r'^dreamreals/', ListView.as_view(
template_name = "dreamreal_list.html")),
model = Dreamreal, context_object_name = ”dreamreals_objects” ,)
관련 템플릿은 다음과 같습니다.
{% extends "main_template.html" %}
{% block content %}
Dreamreals:<p>
{% for dr in object_list %}
{{dr.name}}</p>
{% endfor %}
{% endblock %}
/ myapp / dreamreals /에 액세스하면 다음 페이지가 생성됩니다.
Django에서 양식을 만드는 것은 모델을 만드는 것과 매우 유사합니다. 여기서도 Django 클래스에서 상속하기 만하면 클래스 속성이 양식 필드가됩니다. 추가하자forms.pymyapp 폴더의 파일에 앱 양식이 포함됩니다. 로그인 양식을 작성합니다.
myapp/forms.py
#-*- coding: utf-8 -*-
from django import forms
class LoginForm(forms.Form):
user = forms.CharField(max_length = 100)
password = forms.CharField(widget = forms.PasswordInput())
위에서 본 것처럼 필드 유형은 html 렌더링을 위해 "widget"인수를 사용할 수 있습니다. 우리의 경우 암호가 표시되지 않고 숨겨지기를 원합니다. Django에는 다른 많은 위젯이 있습니다.DateInput 날짜, CheckboxInput 체크 박스 등
보기에서 양식 사용
HTTP 요청에는 GET과 POST의 두 가지 종류가 있습니다. Django에서 뷰에 매개 변수로 전달 된 요청 객체에는 요청 유형이 설정된 "method"라는 속성이 있으며 POST를 통해 전달 된 모든 데이터는 request.POST 사전을 통해 액세스 할 수 있습니다.
myapp / views.py에서 로그인 뷰를 생성 해 보겠습니다.
#-*- coding: utf-8 -*-
from myapp.forms import LoginForm
def login(request):
username = "not logged in"
if request.method == "POST":
#Get the posted form
MyLoginForm = LoginForm(request.POST)
if MyLoginForm.is_valid():
username = MyLoginForm.cleaned_data['username']
else:
MyLoginForm = Loginform()
return render(request, 'loggedin.html', {"username" : username})
보기는를 통해 게시 된 로그인 양식의 결과를 표시합니다. loggedin.html. 이를 테스트하려면 먼저 로그인 양식 템플릿이 필요합니다. login.html이라고합시다.
<html>
<body>
<form name = "form" action = "{% url "myapp.views.login" %}"
method = "POST" >{% csrf_token %}
<div style = "max-width:470px;">
<center>
<input type = "text" style = "margin-left:20%;"
placeholder = "Identifiant" name = "username" />
</center>
</div>
<br>
<div style = "max-width:470px;">
<center>
<input type = "password" style = "margin-left:20%;"
placeholder = "password" name = "password" />
</center>
</div>
<br>
<div style = "max-width:470px;">
<center>
<button style = "border:0px; background-color:#4285F4; margin-top:8%;
height:35px; width:80%;margin-left:19%;" type = "submit"
value = "Login" >
<strong>Login</strong>
</button>
</center>
</div>
</form>
</body>
</html>
템플릿은 로그인 양식을 표시하고 위의 로그인보기에 결과를 게시합니다. 사이트에 대한 CSRF (Cross-site Request Forgery) 공격을 방지하기위한 템플릿에서 태그를 발견했을 것입니다.
{% csrf_token %}
로그인 템플릿이 있으면 양식 처리 후 렌더링 될 login.html 템플릿이 필요합니다.
<html>
<body>
You are : <strong>{{username}}</strong>
</body>
</html>
이제 시작하려면 URL 쌍이 필요합니다. myapp / urls.py
from django.conf.urls import patterns, url
from django.views.generic import TemplateView
urlpatterns = patterns('myapp.views',
url(r'^connection/',TemplateView.as_view(template_name = 'login.html')),
url(r'^login/', 'login', name = 'login'))
"/ myapp / connection"에 액세스 할 때 다음 login.html 템플릿이 렌더링됩니다.
양식 게시물에서 양식이 유효합니다. 우리의 경우 두 필드를 채워야합니다.
귀하의 사용자 이름이 폴로이고 암호를 잊어 버린 경우. 다음 메시지가 표시됩니다.
자체 양식 유효성 검사 사용
위의 예에서 양식의 유효성을 검사 할 때-
MyLoginForm.is_valid()
우리는 Django 자체 양식 유효성 검사 엔진 만 사용했으며,이 경우 필드가 필수인지 확인했습니다. 이제 로그인을 시도하는 사용자가 DB에 Dreamreal 항목으로 존재하는지 확인하겠습니다. 이를 위해 myapp / forms.py를-
#-*- coding: utf-8 -*-
from django import forms
from myapp.models import Dreamreal
class LoginForm(forms.Form):
user = forms.CharField(max_length = 100)
password = forms.CharField(widget = forms.PasswordInput())
def clean_message(self):
username = self.cleaned_data.get("username")
dbuser = Dreamreal.objects.filter(name = username)
if not dbuser:
raise forms.ValidationError("User does not exist in our db!")
return username
이제 "is_valid"메소드를 호출 한 후 사용자가 데이터베이스에있는 경우에만 올바른 출력을 얻을 수 있습니다. 양식의 필드를 확인하려면 "clean_"으로 시작하는 메소드를 추가 한 다음 양식 클래스에 필드 이름을 추가하십시오. form.ValidationError는 중요합니다.
일반적으로 웹 앱이 파일 (프로필 사진, 노래, pdf, 단어 .....)을 업로드 할 수 있으면 유용합니다. 이 장에서 파일을 업로드하는 방법에 대해 설명하겠습니다.
이미지 업로드
이미지 재생을 시작하기 전에 Python 이미지 라이브러리 (PIL)가 설치되어 있는지 확인하십시오. 이제 이미지 업로드를 설명하기 위해 myapp / forms.py에 프로필 양식을 만들어 보겠습니다.
#-*- coding: utf-8 -*-
from django import forms
class ProfileForm(forms.Form):
name = forms.CharField(max_length = 100)
picture = forms.ImageFields()
보시다시피 여기서 가장 큰 차이점은 forms.ImageField. ImageField는 업로드 된 파일이 이미지인지 확인합니다. 그렇지 않으면 양식 유효성 검사가 실패합니다.
이제 업로드 된 프로필을 저장할 "프로필"모델을 만들어 보겠습니다. 이것은 myapp / models.py에서 이루어집니다-
from django.db import models
class Profile(models.Model):
name = models.CharField(max_length = 50)
picture = models.ImageField(upload_to = 'pictures')
class Meta:
db_table = "profile"
모델에서 볼 수 있듯이 ImageField는 필수 인수를 취합니다. upload_to. 이것은 이미지가 저장 될 하드 드라이브의 위치를 나타냅니다. 매개 변수는 settings.py 파일에 정의 된 MEDIA_ROOT 옵션에 추가됩니다.
이제 Form과 Model이 생겼으니 myapp / views.py에 뷰를 생성 해 보겠습니다.
#-*- coding: utf-8 -*-
from myapp.forms import ProfileForm
from myapp.models import Profile
def SaveProfile(request):
saved = False
if request.method == "POST":
#Get the posted form
MyProfileForm = ProfileForm(request.POST, request.FILES)
if MyProfileForm.is_valid():
profile = Profile()
profile.name = MyProfileForm.cleaned_data["name"]
profile.picture = MyProfileForm.cleaned_data["picture"]
profile.save()
saved = True
else:
MyProfileForm = Profileform()
return render(request, 'saved.html', locals())
놓치지 말아야 할 부분은 ProfileForm을 만들 때 변경 사항이 있으며 두 번째 매개 변수를 추가했습니다. request.FILES. 통과하지 못하면 양식 유효성 검사가 실패하고 그림이 비어 있다는 메시지가 표시됩니다.
이제 우리는 saved.html 템플릿 및 profile.html 템플릿, 양식 및 리디렉션 페이지-
myapp/templates/saved.html −
<html>
<body>
{% if saved %}
<strong>Your profile was saved.</strong>
{% endif %}
{% if not saved %}
<strong>Your profile was not saved.</strong>
{% endif %}
</body>
</html>
myapp/templates/profile.html −
<html>
<body>
<form name = "form" enctype = "multipart/form-data"
action = "{% url "myapp.views.SaveProfile" %}" method = "POST" >{% csrf_token %}
<div style = "max-width:470px;">
<center>
<input type = "text" style = "margin-left:20%;"
placeholder = "Name" name = "name" />
</center>
</div>
<br>
<div style = "max-width:470px;">
<center>
<input type = "file" style = "margin-left:20%;"
placeholder = "Picture" name = "picture" />
</center>
</div>
<br>
<div style = "max-width:470px;">
<center>
<button style = "border:0px;background-color:#4285F4; margin-top:8%;
height:35px; width:80%; margin-left:19%;" type = "submit" value = "Login" >
<strong>Login</strong>
</button>
</center>
</div>
</form>
</body>
</html>
다음으로 시작하려면 URL 쌍이 필요합니다. myapp / urls.py
from django.conf.urls import patterns, url
from django.views.generic import TemplateView
urlpatterns = patterns(
'myapp.views', url(r'^profile/',TemplateView.as_view(
template_name = 'profile.html')), url(r'^saved/', 'SaveProfile', name = 'saved')
)
"/ myapp / profile"에 액세스하면 다음 profile.html 템플릿이 렌더링됩니다.
그리고 양식 게시에서 저장된 템플릿이 렌더링됩니다.
이미지 샘플이 있지만 이미지뿐 아니라 다른 유형의 파일을 업로드하려면 ImageField Model과 Form 모두에서 FileField.
지금까지 예제에서는 Django dev 웹 서버를 사용했습니다. 그러나이 서버는 테스트 용이며 프로덕션 환경에는 적합하지 않습니다. 프로덕션 단계에서는 Apache, Nginx 등과 같은 실제 서버가 필요합니다.이 장에서 Apache에 대해 설명하겠습니다.
Apache를 통해 Django 애플리케이션을 제공하는 것은 mod_wsgi를 사용하여 수행됩니다. 따라서 첫 번째는 Apache와 mod_wsgi가 설치되어 있는지 확인하는 것입니다. 프로젝트를 생성하고 프로젝트 구조를 살펴 보았을 때 다음과 같았습니다.
myproject/
manage.py
myproject/
__init__.py
settings.py
urls.py
wsgi.py
wsgi.py 파일은 Django와 Apache 간의 링크를 처리하는 파일입니다.
프로젝트 (myproject)를 Apache와 공유하고 싶다고 가정 해 보겠습니다. 폴더에 액세스하도록 Apache를 설정하기 만하면됩니다. myproject 폴더를 기본 "/ var / www / html"에 넣었다고 가정합니다. 이 단계에서 프로젝트 액세스는 127.0.0.1/myproject를 통해 수행됩니다. 그러면 Apache는 다음 스냅 샷과 같이 폴더를 나열합니다.
보시다시피 Apache는 Django 항목을 처리하지 않습니다. 이를 처리하려면 httpd.conf에서 Apache를 구성해야합니다. 따라서 httpd.conf를 열고 다음 줄을 추가하십시오.
WSGIScriptAlias / /var/www/html/myproject/myproject/wsgi.py
WSGIPythonPath /var/www/html/myproject/
<Directory /var/www/html/myproject/>
<Files wsgi.py>
Order deny,allow
Allow from all
</Files>
</Directory>
로그인 페이지에 127.0.0.1/myapp/connection으로 액세스 할 수 있으면 다음 페이지가 표시됩니다.
웹 응용 프로그램의 요구 사항에 따라 사이트 방문자별로 일부 데이터를 저장하려는 경우가 있습니다. 쿠키는 클라이언트 측에 저장되며 클라이언트 브라우저 보안 수준에 따라 쿠키 설정이 때때로 작동 할 수 있고 때로는 작동하지 않을 수 있음을 항상 명심하십시오.
Django에서 쿠키 처리를 설명하기 위해 이전에 만든 로그인 시스템을 사용하여 시스템을 만들어 보겠습니다. 시스템은 X 분 동안 로그인 상태를 유지하며 그 시간이 지나면 앱에서 나갑니다.
이를 위해서는 last_connection과 username이라는 두 개의 쿠키를 설정해야합니다.
먼저 사용자 이름과 last_connection 쿠키를 저장하도록 로그인 뷰를 변경해 보겠습니다.
from django.template import RequestContext
def login(request):
username = "not logged in"
if request.method == "POST":
#Get the posted form
MyLoginForm = LoginForm(request.POST)
if MyLoginForm.is_valid():
username = MyLoginForm.cleaned_data['username']
else:
MyLoginForm = LoginForm()
response = render_to_response(request, 'loggedin.html', {"username" : username},
context_instance = RequestContext(request))
response.set_cookie('last_connection', datetime.datetime.now())
response.set_cookie('username', datetime.datetime.now())
return response
위의보기에서 볼 수 있듯이 쿠키 설정은 set_cookie 메서드가 요청이 아닌 응답에서 호출되며 모든 쿠키 값이 문자열로 반환됩니다.
이제 로그인 양식에 대한 formView를 생성 해 보겠습니다. 쿠키가 설정되어 있고 10 초보다 오래되지 않은 경우 양식을 표시하지 않습니다.
def formView(request):
if 'username' in request.COOKIES and 'last_connection' in request.COOKIES:
username = request.COOKIES['username']
last_connection = request.COOKIES['last_connection']
last_connection_time = datetime.datetime.strptime(last_connection[:-7],
"%Y-%m-%d %H:%M:%S")
if (datetime.datetime.now() - last_connection_time).seconds < 10:
return render(request, 'loggedin.html', {"username" : username})
else:
return render(request, 'login.html', {})
else:
return render(request, 'login.html', {})
위의 formView에서 볼 수 있듯이 설정 한 쿠키에 액세스하는 것은 요청의 COOKIES 속성 (dict)을 통해 수행됩니다.
이제 url.py 파일을 변경하여 URL을 변경하여 새 뷰와 짝을 이룹니다.
from django.conf.urls import patterns, url
from django.views.generic import TemplateView
urlpatterns = patterns('myapp.views',
url(r'^connection/','formView', name = 'loginform'),
url(r'^login/', 'login', name = 'login'))
/ myapp / connection에 액세스하면 다음 페이지가 표시됩니다.
제출시 다음 화면으로 리디렉션됩니다.
이제 10 초 이내에 / myapp / connection에 다시 액세스하려고하면 두 번째 화면으로 직접 리디렉션됩니다. 이 범위를 벗어나서 / myapp / connection에 다시 액세스하면 로그인 양식 (화면 1)이 표시됩니다.
앞에서 설명한 것처럼 클라이언트 측 쿠키를 사용하여 웹 앱에 유용한 많은 데이터를 저장할 수 있습니다. 이전에 클라이언트 측 쿠키를 사용하여 웹 앱에 유용한 다양한 데이터를 저장할 수 있음을 확인했습니다. 이로 인해 저장하려는 데이터의 중요성에 따라 많은 보안 허점이 발생합니다.
보안상의 이유로 Django에는 쿠키 처리를위한 세션 프레임 워크가 있습니다. 세션은 쿠키의 수신 및 전송을 추상화하는 데 사용되며 데이터는 데이터베이스와 같이 서버 측에 저장되며 클라이언트 측 쿠키에는 식별을위한 세션 ID 만 있습니다. 세션은 사용자 브라우저가 쿠키를 '수락하지 않음'으로 설정하는 경우를 방지하는데도 유용합니다.
세션 설정
Django에서 세션 활성화는 프로젝트에서 수행됩니다. settings.py, 몇 줄을 추가하여 MIDDLEWARE_CLASSES 그리고 INSTALLED_APPS옵션. 이 작업은 프로젝트를 만드는 동안 수행해야하지만 항상 알아두면 좋습니다.MIDDLEWARE_CLASSES 있어야합니다-
'django.contrib.sessions.middleware.SessionMiddleware'
과 INSTALLED_APPS 있어야합니다-
'django.contrib.sessions'
기본적으로 Django는 데이터베이스 (django_session 테이블 또는 컬렉션)에 세션 정보를 저장하지만 다음과 같은 다른 방법을 사용하여 정보를 저장하도록 엔진을 구성 할 수 있습니다. file 또는 cache.
세션이 활성화되면 모든 요청 (Django에서보기의 첫 번째 인수)에는 세션 (dict) 속성이 있습니다.
세션을 만들고 저장하는 방법을 알아보기 위해 간단한 샘플을 만들어 보겠습니다. 이전에 간단한 로그인 시스템을 구축했습니다 (Django 양식 처리 장 및 Django 쿠키 처리 장 참조). 로그 아웃하지 않은 경우 로그인 페이지에 액세스 할 때 로그인 양식을 볼 수 없도록 사용자 이름을 쿠키에 저장하겠습니다. 기본적으로 Django Cookies에서 사용한 로그인 시스템을 서버 측에 저장하여보다 안전하게 만들어 보겠습니다.
이를 위해 먼저 로그인 뷰를 변경하여 사용자 이름 쿠키 서버 측을 저장합니다.
def login(request):
username = 'not logged in'
if request.method == 'POST':
MyLoginForm = LoginForm(request.POST)
if MyLoginForm.is_valid():
username = MyLoginForm.cleaned_data['username']
request.session['username'] = username
else:
MyLoginForm = LoginForm()
return render(request, 'loggedin.html', {"username" : username}
그런 다음 로그인 양식에 대한 formView보기를 생성 해 보겠습니다. 쿠키가 설정되어 있으면 양식을 표시하지 않습니다.
def formView(request):
if request.session.has_key('username'):
username = request.session['username']
return render(request, 'loggedin.html', {"username" : username})
else:
return render(request, 'login.html', {})
이제 url.py 파일을 변경하여 url을 변경하여 새 뷰와 쌍을 이루도록하겠습니다.
from django.conf.urls import patterns, url
from django.views.generic import TemplateView
urlpatterns = patterns('myapp.views',
url(r'^connection/','formView', name = 'loginform'),
url(r'^login/', 'login', name = 'login'))
/ myapp / connection에 액세스하면 다음 페이지가 표시됩니다.
그리고 다음 페이지로 리디렉션됩니다-
이제 / myapp / connection에 다시 액세스하려고하면 두 번째 화면으로 직접 리디렉션됩니다.
쿠키를 지우는 간단한 로그 아웃보기를 만들어 보겠습니다.
def logout(request):
try:
del request.session['username']
except:
pass
return HttpResponse("<strong>You are logged out.</strong>")
그리고 myapp / url.py의 로그 아웃 URL과 페어링합니다.
url(r'^logout/', 'logout', name = 'logout'),
이제 / myapp / logout에 액세스하면 다음 페이지가 표시됩니다.
/ myapp / connection에 다시 액세스하면 로그인 양식이 표시됩니다 (화면 1).
세션을 사용하여 더 많은 가능한 조치
세션을 저장하고 액세스하는 방법을 살펴 보았지만 요청의 세션 속성에 다음과 같은 다른 유용한 작업이 있다는 것을 아는 것이 좋습니다.
set_expiry (value) − 세션 만료 시간을 설정합니다.
get_expiry_age() −이 세션이 만료 될 때까지의 시간 (초)을 반환합니다.
get_expiry_date() −이 세션이 만료되는 날짜를 반환합니다.
clear_expired() − 세션 저장소에서 만료 된 세션을 제거합니다.
get_expire_at_browser_close() − 사용자의 웹 브라우저를 닫을 때 사용자의 세션 쿠키가 만료되었는지 여부에 따라 True 또는 False를 반환합니다.
무언가를 캐시하는 것은 비용이 많이 드는 계산 결과를 저장하여 다음에 필요할 때 수행하지 않도록하는 것입니다. 다음은 캐싱이 작동하는 방식을 설명하는 의사 코드입니다.
given a URL, try finding that page in the cache
if the page is in the cache:
return the cached page
else:
generate the page
save the generated page in the cache (for next time)
return the generated page
Django는 필요할 때 다시 계산하지 않도록 동적 페이지를 저장할 수있는 자체 캐싱 시스템을 제공합니다. Django Cache 프레임 워크의 좋은 점은 캐시 할 수 있다는 것입니다.
- 특정보기의 출력입니다.
- 템플릿의 일부입니다.
- 귀하의 전체 사이트.
Django에서 캐시를 사용하려면 먼저 캐시가 유지 될 위치를 설정해야합니다. 캐시 프레임 워크는 다양한 가능성을 제공합니다. 캐시는 데이터베이스, 파일 시스템 또는 메모리에 직접 저장할 수 있습니다. 설정은settings.py 프로젝트의 파일.
데이터베이스에서 캐시 설정
프로젝트 settings.py 파일에 다음을 추가하십시오.
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
'LOCATION': 'my_table_name',
}
}
이것이 작동하고 설정을 완료하려면 캐시 테이블 'my_table_name'을 생성해야합니다. 이를 위해 다음을 수행해야합니다.
python manage.py createcachetable
파일 시스템에서 캐시 설정
프로젝트 settings.py 파일에 다음을 추가하십시오.
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
'LOCATION': '/var/tmp/django_cache',
}
}
메모리에 캐시 설정
이것은 가장 효율적인 캐싱 방법입니다.이를 사용하려면 메모리 캐시에 대해 선택한 Python 바인딩 라이브러리에 따라 다음 옵션 중 하나를 사용할 수 있습니다.
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': '127.0.0.1:11211',
}
}
Or
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': 'unix:/tmp/memcached.sock',
}
}
전체 사이트 캐싱
Django에서 캐시를 사용하는 가장 간단한 방법은 전체 사이트를 캐시하는 것입니다. 이는 프로젝트 settings.py에서 MIDDLEWARE_CLASSES 옵션을 편집하여 수행됩니다. 옵션에 다음을 추가해야합니다-
MIDDLEWARE_CLASSES += (
'django.middleware.cache.UpdateCacheMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.cache.FetchFromCacheMiddleware',
)
여기서 순서는 중요합니다. 업데이트는 Fetch 미들웨어보다 먼저 와야합니다.
그런 다음 동일한 파일에서 다음을 설정해야합니다.
CACHE_MIDDLEWARE_ALIAS – The cache alias to use for storage.
CACHE_MIDDLEWARE_SECONDS – The number of seconds each page should be cached.
뷰 캐싱
전체 사이트를 캐시하지 않으려면 특정보기를 캐시 할 수 있습니다. 이것은cache_pageDjango와 함께 제공되는 데코레이터. 결과를 캐시하고 싶다고합시다.viewArticles 보기-
from django.views.decorators.cache import cache_page
@cache_page(60 * 15)
def viewArticles(request, year, month):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text)
보시다시피 cache_page보기 결과를 매개 변수로 캐시 할 시간 (초)이 걸립니다. 위의 예에서 결과는 15 분 동안 캐시됩니다.
Note − 위의보기가지도에 표시되기 전에 확인했듯이 −
urlpatterns = patterns('myapp.views',
url(r'^articles/(?P<month>\d{2})/(?P<year>\d{4})/', 'viewArticles', name = 'articles'),)
URL이 매개 변수를 사용하기 때문에 각 호출이 개별적으로 캐시됩니다. 예를 들어, / myapp / articles / 02 / 2007에 대한 요청은 / myapp / articles / 03 / 2008에 별도로 캐시됩니다.
뷰 캐싱은 url.py 파일에서 직접 수행 할 수도 있습니다. 그러면 다음과 같은 결과가 위와 같습니다. myapp / url.py 파일을 편집하고 관련 매핑 된 URL (위)을 다음과 같이 변경하십시오.
urlpatterns = patterns('myapp.views',
url(r'^articles/(?P<month>\d{2})/(?P<year>\d{4})/',
cache_page(60 * 15)('viewArticles'), name = 'articles'),)
물론 myapp / views.py에서는 더 이상 필요하지 않습니다.
템플릿 조각 캐싱
템플릿의 일부를 캐시 할 수도 있습니다.이 작업은 cache꼬리표. 우리를 가져 가자hello.html 템플릿 −
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
콘텐츠 블록을 캐시하기 위해 템플릿은 다음과 같습니다.
{% load cache %}
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% cache 500 content %}
{% block content %}
Hello World!!!<p>Today is {{today}}</p>
We are
{% if today.day == 1 %}
the first day of month.
{% elif today.day == 30 %}
the last day of month.
{% else %}
I don't know.
{%endif%}
<p>
{% for day in days_of_week %}
{{day}}
</p>
{% endfor %}
{% endblock %}
{% endcache %}
위에서 볼 수 있듯이 캐시 태그에는 2 개의 매개 변수가 필요합니다. 블록을 캐시 할 시간 (초)과 캐시 조각에 이름을 지정할 수 있습니다.
시작하기 전에 Django Comments 프레임 워크는 1.5 버전부터 더 이상 사용되지 않습니다. 이제 외부 기능을 사용할 수 있지만 계속 사용하려면 1.6 및 1.7 버전에 여전히 포함되어 있습니다. 버전 1.8부터는 존재하지 않지만 다른 GitHub 계정에서 코드를 얻을 수 있습니다.
댓글 프레임 워크를 사용하면 앱의 모든 모델에 댓글을 쉽게 첨부 할 수 있습니다.
Django 주석 프레임 워크 사용을 시작하려면-
프로젝트 settings.py 파일을 편집하고 'django.contrib.sites', 및 'django.contrib.comments', INSTALLED_APPS 옵션으로-
INSTALLED_APPS += ('django.contrib.sites', 'django.contrib.comments',)
사이트 ID 얻기-
>>> from django.contrib.sites.models import Site
>>> Site().save()
>>> Site.objects.all()[0].id
u'56194498e13823167dd43c64'
settings.py 파일에서 얻은 ID를 설정하십시오-
SITE_ID = u'56194498e13823167dd43c64'
모든 주석 테이블 또는 컬렉션을 생성하려면 db 동기화-
python manage.py syncdb
프로젝트의 urls.py에 댓글 앱의 URL을 추가하세요.
from django.conf.urls import include
url(r'^comments/', include('django.contrib.comments.urls')),
이제 프레임 워크가 설치되었으므로 Dreamreal 모델에 대한 주석을 추적하도록 hello 템플릿을 변경해 보겠습니다. 이름이 / myapp / hello URL에 매개 변수로 전달되는 특정 Dreamreal 항목에 대한 설명을 나열하고 저장합니다.
꿈의 모델
class Dreamreal(models.Model):
website = models.CharField(max_length = 50)
mail = models.CharField(max_length = 50)
name = models.CharField(max_length = 50)
phonenumber = models.IntegerField()
class Meta:
db_table = "dreamreal"
안녕하세요보기
def hello(request, Name):
today = datetime.datetime.now().date()
daysOfWeek = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
dreamreal = Dreamreal.objects.get(name = Name)
return render(request, 'hello.html', locals())
hello.html 템플릿
{% extends "main_template.html" %}
{% load comments %}
{% block title %}My Hello Page{% endblock %}
{% block content %}
<p>
Our Dreamreal Entry:
<p><strong>Name :</strong> {{dreamreal.name}}</p>
<p><strong>Website :</strong> {{dreamreal.website}}</p>
<p><strong>Phone :</strong> {{dreamreal.phonenumber}}</p>
<p><strong>Number of comments :<strong>
{% get_comment_count for dreamreal as comment_count %} {{ comment_count }}</p>
<p>List of comments :</p>
{% render_comment_list for dreamreal %}
</p>
{% render_comment_form for dreamreal %}
{% endblock %}
마지막으로 hello 뷰에 대한 매핑 URL-
url(r'^hello/(?P<Name>\w+)/', 'hello', name = 'hello'),
지금,
템플릿 (hello.html)에서-{% load comments %}를 사용하여 주석 프레임 워크를로드합니다.
뷰에 의해 전달되는 Dreamreal 객체에 대한 댓글 수를 얻습니다 − {% get_comment_count for dreamreal as comment_count %}
객체에 대한 주석 목록을 얻습니다-{% dreamreal %}에 대한 render_comment_list
기본 댓글 양식을 표시합니다-{% dreamreal %}에 대한 render_comment_form
/ myapp / hello / steve에 액세스하면 이름이 Steve 인 Dreamreal 항목에 대한 설명 정보를 얻을 수 있습니다. 해당 URL에 액세스하면-
댓글을 게시하면 다음 페이지로 리디렉션됩니다.
/ myapp / hello / steve로 다시 이동하면 다음 페이지가 표시됩니다.
보시다시피 댓글 수는 이제 1 개이며 댓글 목록 아래에 댓글이 있습니다.
Django는 신디케이션 피드 생성 프레임 워크와 함께 제공됩니다. 그것으로 당신은 RSS 또는 Atom 피드를 만들 수 있습니다.django.contrib.syndication.views.Feed class.
앱에서 수행 한 최신 댓글에 대한 피드를 생성 해 보겠습니다 (Django-Comments Framework 장 참조). 이를 위해 myapp / feeds.py를 만들고 피드를 정의 해 보겠습니다 (코드 구조에서 원하는 위치에 피드 클래스를 배치 할 수 있음).
from django.contrib.syndication.views import Feed
from django.contrib.comments import Comment
from django.core.urlresolvers import reverse
class DreamrealCommentsFeed(Feed):
title = "Dreamreal's comments"
link = "/drcomments/"
description = "Updates on new comments on Dreamreal entry."
def items(self):
return Comment.objects.all().order_by("-submit_date")[:5]
def item_title(self, item):
return item.user_name
def item_description(self, item):
return item.comment
def item_link(self, item):
return reverse('comment', kwargs = {'object_pk':item.pk})
피드 클래스에서 title, link, 및 description 속성은 표준 RSS에 해당합니다. <title>, <link> 과 <description> 집단.
그만큼 items메서드에서 피드에 있어야하는 요소를 항목 요소로 반환합니다. 우리의 경우 마지막 5 개의 댓글입니다.
그만큼 item_title메소드는 피드 항목의 제목으로 이동할 내용을 가져옵니다. 우리의 경우 제목은 사용자 이름이됩니다.
그만큼 item_description메소드는 피드 항목에 대한 설명으로 이동할 내용을 가져옵니다. 우리의 경우 주석 자체입니다.
그만큼 item_link메소드는 전체 항목에 대한 링크를 빌드합니다. 우리의 경우 댓글로 이동합니다.
이제 피드가 있으므로 views.py에 댓글보기를 추가하여 댓글을 표시해 보겠습니다.
from django.contrib.comments import Comment
def comment(request, object_pk):
mycomment = Comment.objects.get(object_pk = object_pk)
text = '<strong>User :</strong> %s <p>'%mycomment.user_name</p>
text += '<strong>Comment :</strong> %s <p>'%mycomment.comment</p>
return HttpResponse(text)
매핑을 위해 myapp urls.py에 URL도 필요합니다.
from myapp.feeds import DreamrealCommentsFeed
from django.conf.urls import patterns, url
urlpatterns += patterns('',
url(r'^latest/comments/', DreamrealCommentsFeed()),
url(r'^comment/(?P\w+)/', 'comment', name = 'comment'),
)
/ myapp / latest / comments /에 액세스하면 피드를 받게됩니다.
그런 다음 사용자 이름 중 하나를 클릭하면 이전에 댓글보기에 정의 된대로 / myapp / comment / comment_id로 이동하고 다음을 얻을 수 있습니다.
따라서 RSS 피드를 정의하는 것은 피드 클래스를 하위 분류하고 URL (하나는 피드에 액세스하고 다른 하나는 피드 요소에 액세스)이 정의되어 있는지 확인하는 것입니다. 댓글처럼 앱의 모든 모델에 첨부 할 수 있습니다.
Ajax는 기본적으로 페이지로드 수를 줄이기 위해 함께 통합 된 기술의 조합입니다. 우리는 일반적으로 Ajax를 사용하여 최종 사용자 경험을 용이하게합니다. Django에서 Ajax를 사용하는 것은 JQuery 또는 기타와 같은 Ajax 라이브러리를 직접 사용하여 수행 할 수 있습니다. JQuery를 사용하려는 경우 Apache 또는 기타를 통해 서버에 라이브러리를 다운로드하고 제공해야한다고 가정 해 보겠습니다. 그런 다음 Ajax 기반 애플리케이션을 개발할 때와 마찬가지로 템플릿에서 사용합니다.
Django에서 Ajax를 사용하는 또 다른 방법은 Django Ajax 프레임 워크를 사용하는 것입니다. 가장 일반적으로 사용되는 것은 django-dajax로, Python을 사용하고 JavaScript 소스 코드를 거의 사용하지 않고 웹 애플리케이션에서 비동기 프레젠테이션 로직을 쉽고 빠르게 개발할 수있는 강력한 도구입니다. 가장 인기있는 4 가지 Ajax 프레임 워크 인 Prototype, jQuery, Dojo 및 MooTools를 지원합니다.
Django-dajax 사용
가장 먼저 할 일은 django-dajax를 설치하는 것입니다. easy_install 또는 pip를 사용하여 수행 할 수 있습니다.
$ pip install django_dajax $ easy_install django_dajax
이것은 django-dajax에 필요한 django-dajaxice를 자동으로 설치합니다. 그런 다음 dajax와 dajaxice를 모두 구성해야합니다.
INSTALLED_APPS 옵션의 프로젝트 settings.py에 dajax 및 dajaxice를 추가하십시오-
INSTALLED_APPS += (
'dajaxice',
'dajax'
)
동일한 settings.py 파일에 다음이 있는지 확인하십시오.
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
'django.template.loaders.eggs.Loader',
)
TEMPLATE_CONTEXT_PROCESSORS = (
'django.contrib.auth.context_processors.auth',
'django.core.context_processors.debug',
'django.core.context_processors.i18n',
'django.core.context_processors.media',
'django.core.context_processors.static',
'django.core.context_processors.request',
'django.contrib.messages.context_processors.messages'
)
STATICFILES_FINDERS = (
'django.contrib.staticfiles.finders.FileSystemFinder',
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
'dajaxice.finders.DajaxiceFinder',
)
DAJAXICE_MEDIA_PREFIX = 'dajaxice'
이제 myapp / url.py 파일로 이동하여 dajax URL을 설정하고 dajax statics js 파일을로드하려면 다음이 있는지 확인하십시오.
from dajaxice.core import dajaxice_autodiscover, dajaxice_config
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.conf import settings
Then dajax urls:
urlpatterns += patterns('',
url(r'^%s/' % settings.DAJAXICE_MEDIA_PREFIX, include('dajaxice.urls')),)
urlpatterns += staticfiles_urlpatterns()
Ajax (새로 고침 없음)를 사용하여 Dreamreal 모델을 기반으로 간단한 양식을 만들어 저장해 보겠습니다.
처음에는 myapp / form.py에 Dreamreal 양식이 필요합니다.
class DreamrealForm(forms.Form):
website = forms.CharField(max_length = 100)
name = forms.CharField(max_length = 100)
phonenumber = forms.CharField(max_length = 50)
email = forms.CharField(max_length = 100)
그런 다음 애플리케이션에 ajax.py 파일이 필요합니다 : myapp / ajax.py. 그것이 우리의 논리가있는 곳입니다. 양식을 저장할 함수를 넣은 다음 팝업을 반환합니다.
from dajaxice.utils import deserialize_form
from myapp.form import DreamrealForm
from dajax.core import Dajax
from myapp.models import Dreamreal
@dajaxice_register
def send_form(request, form):
dajax = Dajax()
form = DreamrealForm(deserialize_form(form))
if form.is_valid():
dajax.remove_css_class('#my_form input', 'error')
dr = Dreamreal()
dr.website = form.cleaned_data.get('website')
dr.name = form.cleaned_data.get('name')
dr.phonenumber = form.cleaned_data.get('phonenumber')
dr.save()
dajax.alert("Dreamreal Entry %s was successfully saved." %
form.cleaned_data.get('name'))
else:
dajax.remove_css_class('#my_form input', 'error')
for error in form.errors:
dajax.add_css_class('#id_%s' % error, 'error')
return dajax.json()
이제 우리의 형식을 가진 dreamreal.html 템플릿을 만들어 보겠습니다.
<html>
<head></head>
<body>
<form action = "" method = "post" id = "my_form" accept-charset = "utf-8">
{{ form.as_p }}
<p><input type = "button" value = "Send" onclick = "send_form();"></p>
</form>
</body>
</html>
myapp / views.py에 템플릿과 함께 제공되는보기를 추가합니다.
def dreamreal(request):
form = DreamrealForm()
return render(request, 'dreamreal.html', locals())
myapp / urls.py에 해당 URL 추가-
url(r'^dreamreal/', 'dreamreal', name = 'dreamreal'),
이제 Ajax가 작동하도록 템플릿에 필요한 항목을 추가해 보겠습니다.
파일 상단에 추가-
{% load static %}
{% load dajaxice_templatetags %}
그리고 dreamreal.html 템플릿의 <head> 섹션에 다음을 추가합니다.
이 예제에서는 JQuery 라이브러리를 사용하고 있으므로 다음을 추가하십시오.
<script src = "{% static '/static/jquery-1.11.3.min.js' %}"
type = "text/javascript" charset = "utf-8"></script>
<script src = "{% static '/static/dajax/jquery.dajax.core.js' %}"></script>
클릭시 호출 될 Ajax 함수-
<script>
function send_form(){
Dajaxice.myapp.send_form(Dajax.process,{'form':$('#my_form').serialize(true)});
}
</script>
정적 파일 디렉토리에 "jquery-1.11.3.min.js"와 jquery.dajax.core.js가 필요합니다. 모든 dajax 정적 파일이 정적 디렉토리에서 제공되는지 확인하려면 다음을 실행하십시오.
$python manage.py collectstatic
Note − 때때로 jquery.dajax.core.js가 누락 될 수 있습니다.이 경우 소스를 다운로드하고 해당 파일을 가져 와서 정적 폴더에 넣으십시오.
/ myapp / dreamreal /에 액세스하면 다음 화면이 표시됩니다. −
제출시 다음 화면이 표시됩니다.