>  기사  >  백엔드 개발  >  Django 버전 진화: 1.x에서 3.x까지, 새로운 기능과 개선 사항에 대해 알아보세요.

Django 버전 진화: 1.x에서 3.x까지, 새로운 기능과 개선 사항에 대해 알아보세요.

王林
王林원래의
2024-01-19 09:46:13512검색

Django 버전 진화: 1.x에서 3.x까지, 새로운 기능과 개선 사항에 대해 알아보세요.

Django는 Python으로 작성된 웹 프레임워크입니다. 주요 특징은 빠른 개발, 쉬운 확장, 높은 재사용성 등입니다. 2005년 처음 출시된 이후 Django는 강력한 웹 개발 프레임워크로 성장했습니다.

시간이 지남에 따라 Django 버전은 지속적으로 업데이트됩니다. 이 기사에서는 Django 버전 진화, 1.x에서 3.x로의 변경 사항에 대한 심층적인 이해를 제공하고, 새로운 기능, 개선 사항 및 주의가 필요한 변경 사항을 소개하고, 자세한 코드 예제를 제공합니다.

  1. Django 1.x 버전

Django 1.x 버전은 Django의 초기 버전으로 1.0.1부터 1.11.29까지 포함되어 있습니다. 이 버전에서 Django는 이미 다음과 같은 많은 기본 기능을 갖추고 있습니다.

a. 데이터베이스 작업에 ORM 사용

ORM은 Django의 핵심 구성 요소입니다. 이를 통해 개발자는 SQL 문을 직접 사용하지 않고도 Python 코드를 사용하여 데이터베이스를 운영할 수 있습니다. ORM은 작업을 보다 쉽고 직관적으로 만듭니다. 간단한 예:

from django.db import models

class Blog(models.Model):
    name = models.CharField(max_length=100)
    tagline = models.TextField()

class Author(models.Model):
    name = models.CharField(max_length=50)
    email = models.EmailField()

class Entry(models.Model):
    blog = models.ForeignKey(Blog, on_delete=models.CASCADE)
    headline = models.CharField(max_length=255)
    body_text = models.TextField()
    pub_date = models.DateTimeField()
    mod_date = models.DateTimeField()
    authors = models.ManyToManyField(Author)
    n_comments = models.IntegerField()
    n_pingbacks = models.IntegerField()
    rating = models.IntegerField()

위 예에서는 Blog, Author 및 Entry라는 세 가지 데이터 모델을 정의했으며 모두 models.Model에서 상속되었습니다. 이러한 클래스의 속성은 데이터베이스 테이블의 필드에 해당합니다. 예를 들어 Blog 클래스에는 문자열 유형 블로그 이름과 슬로건을 각각 저장하는 데 사용되는 이름과 태그라인이라는 두 개의 필드가 있습니다. 데이터 모델을 정의하는 동안 Django는 해당 데이터베이스 테이블, 추가, 삭제, 수정 및 쿼리 작업과 ORM API를 자동으로 생성합니다.

b. URL 자동 관리

Django 1.x 버전에서는 HTTP 요청을 처리하기 위한 뷰 기능만 작성하면 되며, URL을 직접 관리할 필요가 없습니다. Django는 구성된 URL 라우팅을 기반으로 요청을 해당 뷰 기능에 자동으로 매핑합니다. 예:

from django.conf.urls import url
from . import views

urlpatterns = [
    url(r'^$', views.index, name='index'),
    url(r'^(?P<question_id>[0-9]+)/$', views.detail, name='detail'),
    url(r'^(?P<question_id>[0-9]+)/results/$', views.results, name='results'),
    url(r'^(?P<question_id>[0-9]+)/vote/$', views.vote, name='vote'),
]

위의 예에서는 홈페이지, 질문 세부정보 페이지, 투표 결과 페이지, 투표 기능 페이지를 포함한 4개의 URL 경로를 정의했습니다. 각 URL 경로에 대해 해당 처리 기능을 지정합니다. Django는 요청된 URL과 경로를 자동으로 일치시켜 자동으로 URL을 관리하는 기능을 구현합니다.

c. 내장된 관리자 배경 관리 시스템

Django의 관리자 배경 관리 시스템은 매우 강력한 기능입니다. 이 백엔드 관리 시스템을 통해 데이터베이스를 쉽게 추가, 삭제, 수정, 확인할 수 있습니다. Django 1.x 버전의 관리자 백그라운드 관리 시스템에는 이미 관리자 사이트 자동 생성, 데이터 모델 관리, 사용자 정의 목록, 필터 및 양식 표시 등과 같은 많은 기본 기능이 있습니다.

  1. Django 2.x 버전

Django 2.x 버전에는 2.0.0부터 2.2.24까지 포함되어 있으며, 이는 Django에 몇 가지 주요 개선 사항을 제공합니다.

a ASGI 소개

Django 2.x 버전에서는 ASGI(Asynchronous Server Gateway Interface) 프로토콜이 도입되었습니다. ASGI는 개발자가 비동기 웹 애플리케이션을 작성할 수 있도록 하는 비동기 웹 서버용으로 설계된 프로토콜입니다. 이러한 방식으로 웹 소켓, 실시간 통신, 시간이 많이 걸리는 작업 등과 같은 비동기 프로그래밍의 요구 사항을 더 잘 충족할 수 있습니다.

async def application(scope, receive, send):
    assert scope['type'] == 'http'

    await send({
        'type': 'http.response.start',
        'status': 200,
        'headers': [
            [b'content-type', b'text/plain'],
        ]
    })
    await send({
        'type': 'http.response.body',
        'body': b'Hello, world!',
    })

위의 코드 예제에서는 ASGI를 사용하여 간단한 웹 애플리케이션을 작성합니다. 먼저 범위, 수신 및 전송의 세 가지 매개변수를 허용하는 애플리케이션 비동기 함수를 정의합니다. 이러한 매개변수는 ASGI 프로토콜에 의해 고정되고 합의됩니다. 그 중에서 범위는 요청 유형, 경로, 쿼리 문자열 등을 포함하여 요청의 컨텍스트를 나타냅니다. 수신은 요청 수신 방법, 요청 헤더, 응답 코드 등을 나타내는 사전 구성을 나타냅니다. 클라이언트에 응답을 반환합니다.

b. Python 2.x 호환성 제거

Django 2.x 버전에서는 Python 2.x 호환성이 제거되었으며 타사 라이브러리의 Python 2.x 버전은 더 이상 지원되지 않습니다. 이는 개발자가 Django 애플리케이션을 개발하려면 Python 3.x를 사용해야 함을 의미합니다.

또한 Django 2.x 버전에는 다음과 같은 몇 가지 다른 개선 사항과 최적화 기능이 있습니다.

  • 새로운 HTTP 상태 코드 및 예외가 추가되었습니다.
  • 더 나은 비밀번호 보안 메커니즘이 추가되었습니다. 새로운 테스트 프레임워크.
Django 3.x 버전
  1. Django 3.x 버전은 3.0.0부터 3.2.5까지 포함하여 현재 최신 버전입니다. 버전 2.x를 기반으로 기능과 성능이 더욱 향상되었습니다.

a. 경로 매개변수 지원

Django 3.x 버전에서는 Path Converters, 즉 경로 매개변수 지원이 도입되었습니다. 이 새로운 기능은 RESTful API를 개발하는 데 매우 유용하며 URL에 대한 보다 유연한 일치 방법을 제공할 수 있습니다.

from django.urls import path

def greet(request, name):
    return HttpResponse(f'Hello, {name}!')

urlpatterns = [
    path('greet/<name>/', greet),
    ...
]

위의 예에서는 경로 매개변수 이름을 정의했습니다. 요청 경로의 모든 값은 name 매개변수에 채워지고 뷰를 처리할 때 표시될 수 있습니다.

b. UnicodeSlugify 대체

Django 3.x 버전에서는 UnicodeSlugify가 더 이상 기본 Slugify를 대체하는 데 사용되지 않습니다. UnicodeSlugify는 개발자가 더 많은 언어와 문자 집합으로 작업할 수 있도록 하는 타사 라이브러리입니다. UnicodeSlugify 대신, 더 표준화되고, 더 지역화되고, 더 포괄적이고, 더 확장 가능하며 더 안전한 새로운 Slugify 알고리즘이 Django용으로 설계되었습니다.

c. 데이터베이스 쿼리 최적화

Django 3.x 버전에서는 데이터베이스 쿼리 방법이 더욱 최적화되었습니다. 예를 들어 애플리케이션이 시작되면 Django는 모든 데이터베이스 쿼리에 대한 메타데이터를 캐시합니다. 이를 통해 테이블 ​​구조의 조회 횟수를 줄이고 애플리케이션의 응답 속도를 향상시킬 수 있습니다.

또한 Django 3.x 버전에는 다음과 같은 많은 새로운 기능과 개선 사항이 추가되었습니다.

  • 다중 읽기 데이터베이스를 지원하는 새로운 미들웨어
  • 획기적으로 최적화된 쿼리 계획 생성;
  • 비동기 이메일 및 HTTP 요청에 대한 지원이 추가되었습니다.
  • 이 문서에서는 Django 1.x에서 Django 3.x로의 변화에 ​​대해 간략하게 설명합니다. 이러한 변화는 더 나은 성능, 더 나은 개발 효율성, 더 나은 사용 편의성을 제공합니다. MVC 프레임워크로서 Django는 점점 더 완벽해질 것이라고 믿습니다.

위 내용은 Django 버전 진화: 1.x에서 3.x까지, 새로운 기능과 개선 사항에 대해 알아보세요.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.