장고 폐기 일정¶
This document outlines when various pieces of Django will be removed or altered in a backward incompatible way, following their deprecation, as per the deprecation policy. More details about each item can often be found in the release notes of two versions prior.
6.0¶
See the Django 5.0 release notes for more details on these changes.
- The
DjangoDivFormRenderer
andJinja2DivFormRenderer
transitional form renderers will be removed. - Support for passing positional arguments to
BaseConstraint
will be removed. request
will be required in the signature ofModelAdmin.lookup_allowed()
subclasses.- The
django.db.models.sql.datastructures.Join
will no longer fallback toget_joining_columns()
. - The
get_joining_columns()
method ofForeignObject
andForeignObjectRel
will be removed. - The
ForeignObject.get_reverse_joining_columns()
method will be removed. - The default scheme for
forms.URLField
will change from"http"
to"https"
. - Support for calling
format_html()
without passing args or kwargs will be removed. - Support for
cx_Oracle
will be removed. BaseDatabaseOperations.field_cast_sql()
will be removed.- The
ChoicesMeta
alias todjango.db.models.enums.ChoicesType
will be removed. - The
Prefetch.get_current_queryset()
method will be removed. - The
get_prefetch_queryset()
method of related managers and descriptors will be removed. get_prefetcher()
andprefetch_related_objects()
will no longer fallback toget_prefetch_queryset()
.- The
FORMS_URLFIELD_ASSUME_HTTPS
transitional setting will be removed.
5.1¶
See the Django 4.2 release notes for more details on these changes.
- The
BaseUserManager.make_random_password()
method will be removed. - The model’s
Meta.index_together
option will be removed. - The
length_is
template filter will be removed. - The
django.contrib.auth.hashers.SHA1PasswordHasher
,django.contrib.auth.hashers.UnsaltedSHA1PasswordHasher
, anddjango.contrib.auth.hashers.UnsaltedMD5PasswordHasher
will be removed. - The model
django.contrib.postgres.fields.CICharField
,django.contrib.postgres.fields.CIEmailField
, anddjango.contrib.postgres.fields.CITextField
will be removed. Stub fields will remain for compatibility with historical migrations. - The
django.contrib.postgres.fields.CIText
mixin will be removed. - The
map_width
andmap_height
attributes ofBaseGeometryWidget
will be removed. - The
SimpleTestCase.assertFormsetError()
method will be removed. - The
TransactionTestCase.assertQuerysetEqual()
method will be removed. - Support for passing encoded JSON string literals to
JSONField
and associated lookups and expressions will be removed. - Support for passing positional arguments to
Signer
andTimestampSigner
will be removed. - The
DEFAULT_FILE_STORAGE
andSTATICFILES_STORAGE
settings will be removed. - The
django.core.files.storage.get_storage_class()
function will be removed.
5.0¶
이러한 변경사항에 대한 자세한 내용은 :ref::`Django 4.0 release notes <deprecedated-features-4.0>’을 참조하십시오.
- “SERIALIZE” 테스트 설정이 제거됩니다.
- 문서화되지 않은 “django.utils.baseconv” 모듈이 제거됩니다.
- 문서화되지 않은 “django.utils.datetime_safe” 모듈이 제거됩니다.
- “USE_TZ” 설정의 기본값은 “False”에서 “True”로 변경됩니다.
- 요청 컨텍스트 외부에 구축된 사이트 맵의 기본 사이트 맵 프로토콜이 “‘http”에서 “https”로 변경됩니다.
DiscoverRunner.build_suite()
및 ``DiscoverRunner.run_tests()``에 대한 ``extra_tests``인수가 제거됩니다.- The
django.contrib.postgres.aggregates.ArrayAgg
,JSONBAgg
, andStringAgg
aggregates will returnNone
when there are no rows instead of[]
,[]
, and''
respectively. USE_L10N
설정이 제거됩니다.USE_DEPRECATED_PYTZ
전환 설정이 제거됩니다.pytz
시간대 지원이 제거됩니다.is_dst
인수는 다음에서 제거됩니다:QuerySet.datetimes()
django.utils.timezone.make_aware()
django.db.models.functions.Trunc()
django.db.models.functions.TruncSecond()
django.db.models.functions.TruncMinute()
- django.db.models.functions.TruncHour()`
django.db.models.functions.TruncDay()
django.db.models.functions.TruncWeek()
django.db.models.functions.TruncMonth()
django.db.models.functions.TruncQuarter()
django.db.models.functions.TruncYear()
django.contrib.gis.admin.GeoModelAdmin
및OSMGeoAdmin
클래스가 제거됩니다.- 문서화되지 않은
BaseForm._html_output()
메서드는 제거됩니다. ErrorDict
및 ``ErrorList``를 렌더링할 때 ``SafeString``이 아닌 ``str``을 반환하는 기능이 제거됩니다.
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 4.1 릴리스 노트 <deprecated-features-4.1>`를 참조하세요.
SitemapIndexItem.__str__()
메서드가 제거됩니다.CSRF_COOKIE_MASKED
전환 설정이 제거됩니다.django.utils.functional.cached_property()``의 ``name
인수가 제거됩니다.django.contrib.postgres.constraints.ExclusionConstraint``의 ``opclasses
인수가 제거됩니다.errors=None``을 ``SimpleTestCase.assertFormError()
및 ``assertFormsetError()``에 전달하는 문서화되지 않은 기능이 제거됩니다.- ``django.contrib.sessions.serializers.PickleSerializer``가 제거됩니다.
chunk_size
인수를 제공하지 않고 관련 객체를 미리 가져오는 쿼리셋에서QuerySet.iterator()
사용이 더 이상 허용되지 않습니다.- 저장되지 않은 모델 인스턴스를 관련 필터에 전달하는 것은 더 이상 허용되지 않습니다.
created=True``는 ``RemoteUserBackend.configure_user()
하위 클래스의 서명에 필요합니다.django.contrib.auth.views.LogoutView
및``django.contrib.auth.views.logout_then_login()``에서GET
요청을 총한 로그아웃 지원이 제거됩니다.django.utils.timezone.utc
별칭에서 ``datetime.timezone.utc``가 제거됩니다.SimpleTestCase.assertFormError()
및 ``assertFormsetError()``에 응답 객체 및 폼/폼셋 이름을 전달하는 것이 더 이상 허용되지 않습니다.- ``django.contrib.gis.admin.OpenLayersWidget``이 제거됩니다.
- ``django.contrib.auth.hashers.CryptPasswordHasher``가 제거됩니다.
"django/forms/default.html"
및"django/forms/formsets/default.html"
템플릿이 제거됩니다.nulls_first=False
또는nulls_last=False``를 ``Expression.asc()
및Expression.desc()
메서드에 전달하는 기능과OrderBy
표현식은 제거됩니다.
4.1¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 3.2 릴리스 노트 <deprecated-features-3.2>`를 참조하세요.
- ``TestCase.setUpTestData()``의 클래스 속성에 ``copy.deepcopy()``를 사용하여 깊은 복사 생성을 지원하지 않는 개체 할당에 대한 지원이 제거됩니다.
- ``BaseCommand.requires_system_checks``는 부울 값을 지원하지 않습니다.
- ``django.core.validators.EmailValidator``의 ``whitelist``인수 및 ``domain_whitelist``속성이 제거됩니다.
default_app_config
모듈 변수가 제거됩니다.- ``TransactionTestCase.assertQuerysetEqual()``은 문자열 값과 비교할 때 더 이상 쿼리 세트에서 ``repr()``을 자동으로 호출하지 않습니다.
- ``django.core.cache.backends.memcached.MemcachedCache``가 제거됩니다.
- ``django.conrib.messages.storage.cookie.CookieStorage``에서 사용하는 Django 3.2 이전 형식의 메시지에 대한 지원이 제거됩니다.
4.0¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 3.0 릴리스 노트 <deprecated-features-3.0>`을 참조하세요
django.utils.http.urlquote()
,urlquote_plus()
,urlunquote()
및 ``urlunquote_plus()``가 제거됩니다.django.utils.encoding.force_text()
및 ``smart_text()``가 제거됩니다.django.utils.translation.ugettext()
,ugettext_lazy()
,ugettext_noop()
,ungettext()
및 ``ungettext_lazy()``가 제거됩니다.django.views.i18n.set_language()``는 더 이상 ``request.session``(키 ``django.utils.translation.LANGUAGE_SESSION_KEY
)에서 사용자 언어를 설정하지 않습니다.alias=None``은 ``django.db.models.Expression.get_group_by_cols()
하위 클래스의 서명에 필요합니다.- ``django.utils.text.unescape_entities()``가 제거됩니다.
- ``django.utils.http.is_safe_url()``가 제거됩니다.
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 3.1 릴리스 노트 <deprecated-features-3.1>`를 참조하십시오.
PASSWORD_RESET_TIMEOUT_DAYS
설정이 제거됩니다.- 부울이 아닌 값을 우변으로 사용하는
isnull
조회의 문서화되지 않은 사용은 더 이상 허용되지 않습니다. django.db.models.query_utils.InvalidQuery
예외 클래스가 제거됩니다.django-admin.py
진입점이 제거됩니다.HttpRequest.is_ajax()
메서드가 제거됩니다.- ``django.contrib.messages.storage.cookie.CookieStorage``에서 사용하는 쿠키 값의 Django 3.1 이전 인코딩 형식에 대한 지원이 제거됩니다.
- 관리 사이트(SHA-1 해싱 알고리즘 사용)에서 Django 3.1 이전 암호 재설정 토큰에 대한 지원이 제거됩니다.
- 세션의 Django 3.1 이전 인코딩 형식에 대한 지원이 제거됩니다.
- Django 3.1 이전
django.core.signing.Signer
서명(SHA-1 알고리즘으로 인코딩됨)에 대한 지원이 제거됩니다. django.core.signing.loads()``에서 Django 3.1 이전 ``django.core.signing.dumps()
서명(SHA-1 알고리즘으로 인코딩됨)에 대한 지원이 제거됩니다.- Django 3.1 이전 사용자 세션(SHA-1 알고리즘 사용)에 대한 지원이 제거됩니다.
django.utils.deprecation.MiddlewareMixin.__init__()``에 대한 ``get_response
인수가 필요하며 ``None``을 허용하지 않습니다.django.dispatch.Signal``에 대한 ``providing_args
인수가 제거됩니다.django.utils.crypto.get_random_string()``에 대한 ``length
인수가 필요합니다.ModelMultipleChoiceField``에 대한 ``list
메시지가 제거됩니다.- 원시 열 별칭을 ``QuerySet.order_by()``에 전달하는 지원이 제거됩니다.
NullBooleanField
모델이 제거됩니다. 이전 마이그레이션과의 호환성을 위해 스텁 필드가 유지됩니다.- ``django.conf.urls.url()``이 제거됩니다.
django.contrib.postgres.fields.JSONField
모델이 제거됩니다. 이전 마이그레이션과의 호환성을 위해 스텁 필드가 유지됩니다.django.contrib.postgres.forms.JSONField
,django.contrib.postgres.fields.jsonb.KeyTransform
및 ``django.contrib.postgres.fields.jsonb.KeyTextTransform``이 제거됩니다.{% ifequal %}
및{% ifnotequal %}
템플릿 태그가 제거됩니다.DEFAULT_HASHING_ALGORITHM
전환 설정이 제거됩니다.
3.1¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 2.2 릴리스 노트 <deprecated-features-2.2>`를 참조하세요.
- ``django.utils.timezone.FixedOffset``이 제거됩니다.
- ``django.core.paginator.QuerySetPaginator``가 제거됩니다.
- 모델의
Meta.ordering``은 더 이상 ``GROUP BY
쿼리에 영향을 미치지 않습니다. django.contrib.postgres.fields.FloatRangeField
및 ``django.contrib.postgres.forms.FloatRangeField``가 제거됩니다.FILE_CHARSET
설정이 제거됩니다.- ``django.contrib.staticfiles.storage.CachedStaticFilesStorage``가 제거됩니다.
- ``RemoteUserBackend.configure_user()``는 첫 번째 인수로 ``request``를 요구합니다.
SimpleTestCase.allow_database_queries
및TransactionTestCase.multi_db
지원이 제거됩니다.
3.0¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 2.0 릴리스 노트<deprecated-features-2.0>`를 참조하십시오.
django.db.backends.postgresql_psycopg2
모듈이 제거됩니다.- ``django.shortcuts.render_to_response()``가 제거됩니다.
DEFAULT_CONTENT_TYPE
설정이 제거됩니다.- ``HttpRequest.xreadlines()``가 제거됩니다.
Field.from_db_value()
및Expression.convert_value()``의 ``context
인수에 대한 지원이 제거됩니다.QuerySet.earliest()
및latest()``의 ``field_name
키워드 인수가 제거됩니다.
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 2.1 릴리스 노트 <deprecated-features-2.1>`를 참조하십시오.
2.1¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 1.11 릴리스 노트<deprecated-features-1.11>`를 참조하십시오.
contrib.auth.views.login()
,logout()
,password_change()
,password_change_done()
,password_reset()
,password_reset_done( )
,password_reset_confirm()
및 ``password_reset_complete()``가 제거됩니다.contrib.auth.views.logout_then_login()``의 ``extra_context
매개변수가 제거됩니다.- ``django.test.runner.setup_databases()``가 제거됩니다.
- ``django.utils.translation.string_concat()``이 제거됩니다.
django.core.cache.backends.memcached.PyLibMCCache``는 더 이상 ``pylibmc
동작 설정을 ``OPTIONS``의 최상위 속성으로 전달하는 것을 지원하지 않습니다.django.utils.http.is_safe_url()``의 ``host
매개변수가 제거됩니다.{% include %}
템플렛 태그를 렌더링하는 동안 발생한 예외 무시가 제거됩니다.- ``DatabaseIntrospection.get_indexes()``가 제거됩니다.
- 인증 백엔드의
authenticate()
메서드는 첫 번째 인수로 ``request``를 요구합니다. django.db.models.permalink()
데코레이터가 제거됩니다.USE_ETAGS
설정이 제거됩니다.CommonMiddleware
및 ``django.utils.cache.patch_response_headers()``는 더 이상 ETag를 설정하지 않습니다.Model._meta.has_auto_field
속성이 제거됩니다.- 정규표현식 그룹(
(?i)
,(?L)
,(?m)
,(?s)
, and(?u)
) 의 인라인 플래그에 대한 ``url()``의 지원이 제거됩니다. renderer
인수가 없는Widget.render()
메서드에 대한 지원이 제거됩니다.
2.0¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 1.9 릴리스 노트<deprecated-features-1.9>`를 참조하세요.
django.dispatch.signals.Signal.disconnect()``에 대한 ``weak
인수가 제거됩니다.- ``django.db.backends.base.BaseDatabaseOperations.check_aggregate_support()``가 제거됩니다.
django.forms.extras
패키지가 제거됩니다.assignment_tag
도우미가 제거됩니다.assertsRedirects``에 대한 ``host
인수가 제거됩니다. 경로가 동일한 경우 절대 URL을 상대 URL과 동일하게 간주할 수 있는 호환성 계층도 제거됩니다.- ``Field.rel``이 제거됩니다.
Field.remote_field.to
속성이 제거됩니다.ForeignKey
및OneToOneField``에 대한 ``on_delete
인수가 필요합니다.- ``django.db.models.fields.add_lazy_relation()``이 제거됩니다.
- 시간대 지원이 활성화되면 시간대를 지원하지 않는 데이터베이스 백엔드는 이러한 값이 ORM 외부에서 실행되는 SQL 쿼리(``cursor.execute()``를 사용하는)에 매개변수로 전달될 때 더 이상 인식 날짜 시간을 UTC의 순진한 값으로 변환하지 않습니다.
django.contrib.auth.tests.utils.skipIfCustomUser()
데코레이터가 제거됩니다.GeoManager
및GeoQuerySet
클래스가 제거됩니다.django.contrib.gis.geoip
모듈이 제거됩니다.- 템플릿 로더에 대한
supports_recursion
검사가 다음에서 제거됩니다.django.template.engine.Engine.find_template()
django.template.loader_tags.ExtendsNode.find_template()
django.template.loaders.base.Loader.supports_recursion()
django.template.loaders.cached.Loader.supports_recursion()
load_template()
및load_template_sources()
템플릿 로더 메서드는 제거됩니다.- 템플릿 로더에 대한
template_dirs
인수가 제거됩니다:django.template.loaders.base.Loader.get_template()
django.template.loaders.cached.Loader.cache_key()
django.template.loaders.cached.Loader.get_template()
django.template.loaders.cached.Loader.get_template_sources()
django.template.loaders.filesystem.Loader.get_template_sources()
django.template.loaders.base.Loader.__call__()
메서드가 제거됩니다.- 단일 위치 매개변수가 있는 사용자 지정 오류 보기에 대한 지원이 중단됩니다.
django.utils.feedgenerator.Atom1Feed
및django.utils.feedgenerator.RssFeed``의 ``mime_type
속성은 ``content_type``을 위해 제거됩니다.django.conf.urls.include()``에 대한 ``app_name
인수가 제거됩니다.- ``include()``에 대한 첫 번째 인수로 3-튜플을 전달하는 지원이 제거됩니다.
- 애플리케이션 네임스페이스 없이 URL 인스턴스 네임스페이스를 설정하는 지원이 제거됩니다.
- ``Field._get_val_from_obj()``는 ``Field.value_from_object()``를 위해 제거됩니다.
- ``django.template.loaders.eggs.Loader``가 제거됩니다.
contrib.auth
보기에 대한current_app
매개변수가 제거됩니다.SimpleTestCase.assertRaisesMessage()``에 대한 ``callable_obj
키워드 인수가 제거됩니다.ModelAdmin
메서드의allow_tags
속성에 대한 지원이 제거됩니다.SyndicationFeed.add_item()``에 대한 ``enclosure
키워드 인수가 제거됩니다.django.template.base.Origin``의 ``django.template.loader.LoaderOrigin
및django.template.base.StringOrigin
별칭이 제거됩니다.
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 1.10 릴리스 노트 <deprecated-features-1.10>`를 참조하세요.
makemigrations --exit
옵션이 제거됩니다.- 역방향 외래 키 또는 다대다 관계에 대한 직접 할당 지원이 제거됩니다.
django.contrib.gis.geos.GEOSGeometry``의 ``get_srid()
및set_srid()
메소드가 제거됩니다.django.contrib.gis.geos.Point``의 ``get_x()
,set_x()
,get_y()
,set_y()
,get_z()
및set_z()
메서드가 제거됩니다.django.contrib.gis.geos.Point``의 ``get_coords()
및set_coords()
메서드가 제거됩니다.django.contrib.gis.geos.MultiPolygon``의 ``cascaded_union
속성이 제거됩니다.- ``django.utils.functional.allow_lazy()``가 제거됩니다.
shell --plain
옵션이 제거됩니다.django.core.urlresolvers
모듈이 제거됩니다.CommaSeparatedIntegerField
모델이 제거됩니다. 이전 마이그레이션과의 호환성을 위해 스텁 필드가 유지됩니다.- 템플릿
Context.has_key()
메서드에 대한 지원이 제거됩니다. django.core.files.storage.Storage.accessed_time()
,created_time()
및modified_time()
메서드에 대한 지원이 제거됩니다.- ``Meta.default_related_name``이 설정된 경우 모델 이름을 사용한 쿼리 조회 지원이 제거됩니다.
__search
쿼리 조회 및DatabaseOperations.fulltext_search_sql()
메서드가 제거됩니다._apply_rel_filters()
메서드 없이 사용자 지정 관련 관리자 클래스를 지원하기 위한 shim이 제거됩니다.User.is_authenticated()
및 ``User.is_anonymous()``를 메소드로 사용하는 것은 더 이상 지원되지 않습니다.- ``Model._meta``의 비공개 속성 ``virtual_fields``가 제거됩니다.
Field.contribute_to_class()``의 ``virtual_only
및Model._meta.add_field()``의 ``virtual
비공개 키워드 인수가 제거됩니다.javascript_catalog()
및json_catalog()
보기가 제거됩니다.django.contrib.gis.utils.precision_wkt()
함수가 제거됩니다.- 다중 테이블 상속에서 ``OneToOneField``에서 ``parent_link``로의 암시적 확장이 제거됩니다.
- ``Widget._format_value()``에 대한 지원이 제거됩니다.
FileField
메서드get_directory_name()
및 ``get_filename()``이 제거됩니다.mark_for_escaping()
함수와EscapeData
,EscapeBytes
,EscapeText
,EscapeString
및EscapeUnicode
클래스가 제거됩니다.escape
필터는 ``django.utils.html.conditional_escape()``를 사용하도록 변경됩니다.- ``Manager.use_for_related_fields``가 제거됩니다.
- 모델
Manager
상속은 MRO 상속 규칙을 따르며 이 동작을 선택하는 ``Meta.manager_inheritance_from_future``는 제거됩니다. - ``settings.MIDDLEWARE_CLASSES``를 사용하는 구식 미들웨어에 대한 지원이 제거됩니다.
1.10¶
이러한 변경 사항에 대한 자세한 내용은 :ref:`Django 1.8 릴리스 노트<deprecated-features-1.8>`를 참조하십시오.
quote_name_unless_alias
메서드를 호출하기 위한 별칭으로 ``SQLCompiler``를 직접 호출하는 지원이 제거됩니다.cycle
및firstof
템플릿 태그는future
템플릿 태그 라이브러리에서 제거됩니다(1.6/1.7 지원 중단 기간 동안 사용됨).- ``django.conf.urls.patterns()``가 제거됩니다.
django.conf.urls.i18n.i18n_patterns()``에 대한 ``prefix
인수 지원이 제거됩니다.- ``SimpleTestCase.urls``가 제거됩니다.
for
템플릿 태그에서 압축 해제된 값의 잘못된 개수를 사용하면 조용히 실패하지 않고 예외가 발생합니다.- 점으로 구분된 Python 경로를 사용하여 URL을 뒤집는 기능이 제거됩니다.
LOGIN_URL
및LOGIN_REDIRECT_URL
설정에 점으로 구분된 Python 경로를 사용하는 기능이 제거됩니다.- 사용자 지정 관리 명령에 대한
optparse
지원이 중단됩니다( :py:mod:`argparse`로 대체됩니다). django.core.management.NoArgsCommand
클래스가 제거됩니다. 기본적으로 인수를 사용하지 않는 클래스:`~django.core.management.BaseCommand`를 대신 사용하십시오.django.core.context_processors
모듈이 제거됩니다.django.db.models.sql.aggregates
모듈이 제거됩니다.django.contrib.gis.db.models.sql.aggregates
모듈이 제거됩니다.- ``django.db.sql.query.Query``의 다음 메서드 및 속성이 제거됩니다.
- 속성:
aggregates
및aggregate_select
- 메소드:
add_aggregate
,set_aggregate_mask
및append_aggregate_mask
- 속성:
- ``django.template.resolve_variable``이 제거됩니다.
- 다음 비공개 API는
django.db.models.options.Options`(``Model._meta`
)에서 제거됩니다.get_field_by_name()
get_all_field_names()
get_fields_with_model()
get_concrete_fields_with_model()
get_m2m_with_model()
get_all_related_objects()
get_all_related_objects_with_model()
get_all_related_many_to_many_objects()
get_all_related_m2m_objects_with_model()
django.forms.RegexField``의 ``error_message
인수가 제거됩니다.- The
unordered_list
filter will no longer support old style lists. url()``에 대한 문자열 ``view
인수에 대한 지원이 제거됩니다.- ``django.forms.Form._has_changed()``를 ``has_changed()``로 이름을 바꾸는 이전 버전과 호환되는 심이 제거됩니다.
removetags
템플릿 필터가 제거됩니다.django.utils.html``의 ``remove_tags()
및strip_entities()
함수가 제거됩니다.django.contrib.auth.views.password_reset()``에 대한 ``is_admin_site
인수가 제거됩니다.django.db.models.field.subclassing.SubfieldBase
will be removed.django.utils.checksums
will be removed; its functionality is included indjango-localflavor
1.1+.- The
original_content_type_id
attribute ondjango.contrib.admin.helpers.InlineAdminForm
will be removed. - The backwards compatibility shim to allow
FormMixin.get_form()
to be defined with no default value for itsform_class
argument will be removed. - The following settings will be removed:
ALLOWED_INCLUDE_ROOTS
TEMPLATE_CONTEXT_PROCESSORS
TEMPLATE_DEBUG
TEMPLATE_DIRS
TEMPLATE_LOADERS
TEMPLATE_STRING_IF_INVALID
- The backwards compatibility alias
django.template.loader.BaseLoader
will be removed. - Django template objects returned by
get_template()
andselect_template()
won’t accept aContext
in theirrender()
method anymore. - Template response APIs will enforce the use
of
dict
and backend-dependent template objects instead ofContext
andTemplate
respectively. - The
current_app
parameter for the following function and classes will be removed:django.shortcuts.render()
django.template.Context()
django.template.RequestContext()
django.template.response.TemplateResponse()
- The
dictionary
andcontext_instance
parameters for the following functions will be removed:django.shortcuts.render()
django.shortcuts.render_to_response()
django.template.loader.render_to_string()
- The
dirs
parameter for the following functions will be removed:django.template.loader.get_template()
django.template.loader.select_template()
django.shortcuts.render()
django.shortcuts.render_to_response()
- Session verification will be enabled regardless of whether or not
'django.contrib.auth.middleware.SessionAuthenticationMiddleware'
is inMIDDLEWARE_CLASSES
. - Private attribute
django.db.models.Field.related
will be removed. - The
--list
option of themigrate
management command will be removed. - The
ssi
template tag will be removed. - Support for the
=
comparison operator in theif
template tag will be removed. - The backwards compatibility shims to allow
Storage.get_available_name()
andStorage.save()
to be defined without amax_length
argument will be removed. - Support for the legacy
%(<foo>)s
syntax inModelFormMixin.success_url
will be removed. GeoQuerySet
aggregate methodscollect()
,extent()
,extent3d()
,make_line()
, andunionagg()
will be removed.- Ability to specify
ContentType.name
when creating a content type instance will be removed. - Support for the old signature of
allow_migrate
will be removed. It changed fromallow_migrate(self, db, model)
toallow_migrate(self, db, app_label, model_name=None, **hints)
. - Support for the syntax of
{% cycle %}
that uses comma-separated arguments will be removed. - The warning that
Signer
issues when given an invalid separator will become an exception.
1.9¶
See the Django 1.7 release notes for more details on these changes.
django.utils.dictconfig
will be removed.django.utils.importlib
will be removed.django.utils.tzinfo
will be removed.django.utils.unittest
will be removed.- The
syncdb
command will be removed. django.db.models.signals.pre_syncdb
anddjango.db.models.signals.post_syncdb
will be removed.allow_syncdb
on database routers will no longer automatically becomeallow_migrate
.- Automatic syncing of apps without migrations will be removed. Migrations will
become compulsory for all apps unless you pass the
--run-syncdb
option tomigrate
. - The SQL management commands for apps without migrations,
sql
,sqlall
,sqlclear
,sqldropindexes
, andsqlindexes
, will be removed. - Support for automatic loading of
initial_data
fixtures and initial SQL data will be removed. - All models will need to be defined inside an installed application or
declare an explicit
app_label
. Furthermore, it won’t be possible to import them before their application is loaded. In particular, it won’t be possible to import models inside the root package of their application. - The model and form
IPAddressField
will be removed. A stub field will remain for compatibility with historical migrations. AppCommand.handle_app()
will no longer be supported.RequestSite
andget_current_site()
will no longer be importable fromdjango.contrib.sites.models
.- FastCGI support via the
runfcgi
management command will be removed. Please deploy your project using WSGI. django.utils.datastructures.SortedDict
will be removed. Usecollections.OrderedDict
from the Python standard library instead.ModelAdmin.declared_fieldsets
will be removed.- Instances of
util.py
in the Django codebase have been renamed toutils.py
in an effort to unify all util and utils references. The modules that provided backwards compatibility will be removed:django.contrib.admin.util
django.contrib.gis.db.backends.util
django.db.backends.util
django.forms.util
ModelAdmin.get_formsets
will be removed.- The backward compatibility shim introduced to rename the
BaseMemcachedCache._get_memcache_timeout()
method toget_backend_timeout()
will be removed. - The
--natural
and-n
options fordumpdata
will be removed. - The
use_natural_keys
argument forserializers.serialize()
will be removed. - Private API
django.forms.forms.get_declared_fields()
will be removed. - The ability to use a
SplitDateTimeWidget
withDateTimeField
will be removed. - The
WSGIRequest.REQUEST
property will be removed. - The class
django.utils.datastructures.MergeDict
will be removed. - The
zh-cn
andzh-tw
language codes will be removed and have been replaced by thezh-hans
andzh-hant
language code respectively. - The internal
django.utils.functional.memoize
will be removed. django.core.cache.get_cache
will be removed. Add suitable entries toCACHES
and usedjango.core.cache.caches
instead.django.db.models.loading
will be removed.- Passing callable arguments to querysets will no longer be possible.
BaseCommand.requires_model_validation
will be removed in favor ofrequires_system_checks
. Admin validators will be replaced by admin checks.- The
ModelAdmin.validator_class
anddefault_validator_class
attributes will be removed. ModelAdmin.validate()
will be removed.django.db.backends.DatabaseValidation.validate_field
will be removed in favor of thecheck_field
method.- The
validate
management command will be removed. django.utils.module_loading.import_by_path
will be removed in favor ofdjango.utils.module_loading.import_string
.ssi
andurl
template tags will be removed from thefuture
template tag library (used during the 1.3/1.4 deprecation period).django.utils.text.javascript_quote
will be removed.- Database test settings as independent entries in the database settings,
prefixed by
TEST_
, will no longer be supported. - The
cache_choices
option toModelChoiceField
andModelMultipleChoiceField
will be removed. - The default value of the
RedirectView.permanent
attribute will change fromTrue
toFalse
. django.contrib.sitemaps.FlatPageSitemap
will be removed in favor ofdjango.contrib.flatpages.sitemaps.FlatPageSitemap
.- Private API
django.test.utils.TestTemplateLoader
will be removed. - The
django.contrib.contenttypes.generic
module will be removed. - Private APIs
django.db.models.sql.where.WhereNode.make_atom()
anddjango.db.models.sql.where.Constraint
will be removed.
1.8¶
See the Django 1.6 release notes for more details on these changes.
django.contrib.comments
will be removed.- The following transaction management APIs will be removed:
TransactionMiddleware
,- the decorators and context managers
autocommit
,commit_on_success
, andcommit_manually
, defined indjango.db.transaction
, - the functions
commit_unless_managed
androllback_unless_managed
, also defined indjango.db.transaction
, - the
TRANSACTIONS_MANAGED
setting.
- The
cycle
andfirstof
template tags will auto-escape their arguments. In 1.6 and 1.7, this behavior is provided by the version of these tags in thefuture
template tag library. - The
SEND_BROKEN_LINK_EMAILS
setting will be removed. Add thedjango.middleware.common.BrokenLinkEmailsMiddleware
middleware to yourMIDDLEWARE_CLASSES
setting instead. django.middleware.doc.XViewMiddleware
will be removed. Usedjango.contrib.admindocs.middleware.XViewMiddleware
instead.Model._meta.module_name
was renamed tomodel_name
.- Remove the backward compatible shims introduced to rename
get_query_set
and similar queryset methods. This affects the following classes:BaseModelAdmin
,ChangeList
,BaseCommentNode
,GenericForeignKey
,Manager
,SingleRelatedObjectDescriptor
andReverseSingleRelatedObjectDescriptor
. - Remove the backward compatible shims introduced to rename the attributes
ChangeList.root_query_set
andChangeList.query_set
. django.views.defaults.shortcut
will be removed, as part of the goal of removing alldjango.contrib
references from the core Django codebase. Instead usedjango.contrib.contenttypes.views.shortcut
.django.conf.urls.shortcut
will also be removed.- Support for the Python Imaging Library (PIL) module will be removed, as it no longer appears to be actively maintained & does not work on Python 3.
- The following private APIs will be removed:
django.db.backend
django.db.close_connection()
django.db.backends.creation.BaseDatabaseCreation.set_autocommit()
django.db.transaction.is_managed()
django.db.transaction.managed()
django.forms.widgets.RadioInput
will be removed in favor ofdjango.forms.widgets.RadioChoiceInput
.- The module
django.test.simple
and the classdjango.test.simple.DjangoTestSuiteRunner
will be removed. Instead usedjango.test.runner.DiscoverRunner
. - The module
django.test._doctest
will be removed. Instead use the doctest module from the Python standard library. - The
CACHE_MIDDLEWARE_ANONYMOUS_ONLY
setting will be removed. - Usage of the hard-coded Hold down “Control”, or “Command” on a Mac, to select
more than one. string to override or append to user-provided
help_text
in forms for ManyToMany model fields will not be performed by Django anymore either at the model or forms layer. - The
Model._meta.get_(add|change|delete)_permission
methods will be removed. - The session key
django_language
will no longer be read for backwards compatibility. - Geographic Sitemaps will be removed
(
django.contrib.gis.sitemaps.views.index
anddjango.contrib.gis.sitemaps.views.sitemap
). django.utils.html.fix_ampersands
, thefix_ampersands
template filter anddjango.utils.html.clean_html
will be removed following an accelerated deprecation.
1.7¶
See the Django 1.5 release notes for more details on these changes.
- The module
django.utils.simplejson
will be removed. The standard library providesjson
which should be used instead. - The function
django.utils.itercompat.product
will be removed. The Python builtin version should be used instead. - Auto-correction of INSTALLED_APPS and TEMPLATE_DIRS settings when they are specified as a plain string instead of a tuple will be removed and raise an exception.
- The
mimetype
argument to the__init__
methods ofHttpResponse
,SimpleTemplateResponse
, andTemplateResponse
, will be removed.content_type
should be used instead. This also applies to therender_to_response()
shortcut and the sitemap views,index()
andsitemap()
. - When
HttpResponse
is instantiated with an iterator, or whencontent
is set to an iterator, that iterator will be immediately consumed. - The
AUTH_PROFILE_MODULE
setting, and theget_profile()
method on the User model, will be removed. - The
cleanup
management command will be removed. It’s replaced byclearsessions
. - The
daily_cleanup.py
script will be removed. - The
depth
keyword argument will be removed fromselect_related()
. - The undocumented
get_warnings_state()
/restore_warnings_state()
functions fromdjango.test.utils
and thesave_warnings_state()
/restore_warnings_state()
django.test.*TestCase methods are deprecated. Use thewarnings.catch_warnings
context manager available starting with Python 2.6 instead. - The undocumented
check_for_test_cookie
method inAuthenticationForm
will be removed following an accelerated deprecation. Users subclassing this form should remove calls to this method, and instead ensure that their auth related views are CSRF protected, which ensures that cookies are enabled. - The version of
django.contrib.auth.views.password_reset_confirm()
that supports base36 encoded user IDs (django.contrib.auth.views.password_reset_confirm_uidb36
) will be removed. If your site has been running Django 1.6 for more thanPASSWORD_RESET_TIMEOUT_DAYS
, this change will have no effect. If not, then any password reset links generated before you upgrade to Django 1.7 won’t work after the upgrade. - The
django.utils.encoding.StrAndUnicode
mix-in will be removed.
1.6¶
See the Django 1.4 release notes for more details on these changes.
django.contrib.databrowse
will be removed.django.contrib.localflavor
will be removed following an accelerated deprecation.django.contrib.markup
will be removed following an accelerated deprecation.- The compatibility modules
django.utils.copycompat
anddjango.utils.hashcompat
as well as the functionsdjango.utils.itercompat.all
anddjango.utils.itercompat.any
will be removed. The Python builtin versions should be used instead. - The
csrf_response_exempt
andcsrf_view_exempt
decorators will be removed. Since 1.4csrf_response_exempt
has been a no-op (it returns the same function), andcsrf_view_exempt
has been a synonym fordjango.views.decorators.csrf.csrf_exempt
, which should be used to replace it. - The
django.core.cache.backends.memcached.CacheClass
backend was split into two in Django 1.3 in order to introduce support for PyLibMC. The historicalCacheClass
will be removed in favor ofdjango.core.cache.backends.memcached.MemcachedCache
. - The UK-prefixed objects of
django.contrib.localflavor.uk
will only be accessible through their GB-prefixed names (GB is the correct ISO 3166 code for United Kingdom). - The
IGNORABLE_404_STARTS
andIGNORABLE_404_ENDS
settings have been superseded byIGNORABLE_404_URLS
in the 1.4 release. They will be removed. - The form wizard has been refactored to use class-based views with pluggable backends in 1.4. The previous implementation will be removed.
- Legacy ways of calling
cache_page()
will be removed. - The backward-compatibility shim to automatically add a debug-false
filter to the
'mail_admins'
logging handler will be removed. TheLOGGING
setting should include this filter explicitly if it is desired. - The builtin truncation functions
django.utils.text.truncate_words()
anddjango.utils.text.truncate_html_words()
will be removed in favor of thedjango.utils.text.Truncator
class. - The
django.contrib.gis.geoip.GeoIP
class was moved todjango.contrib.gis.geoip
in 1.4 – the shortcut indjango.contrib.gis.utils
will be removed. django.conf.urls.defaults
will be removed. The functionsinclude()
,patterns()
, andurl()
, plushandler404
andhandler500
are now available throughdjango.conf.urls
.- The functions
setup_environ()
andexecute_manager()
will be removed fromdjango.core.management
. This also means that the old (pre-1.4) style ofmanage.py
file will no longer work. - Setting the
is_safe
andneeds_autoescape
flags as attributes of template filter functions will no longer be supported. - The attribute
HttpRequest.raw_post_data
was renamed toHttpRequest.body
in 1.4. The backward compatibility will be removed –HttpRequest.raw_post_data
will no longer work. - The value for the
post_url_continue
parameter inModelAdmin.response_add()
will have to be eitherNone
(to redirect to the newly created object’s edit page) or a pre-formatted url. String formats, such as the previous default'../%s/'
, will not be accepted any more.
1.5¶
See the Django 1.3 release notes for more details on these changes.
- Starting Django without a
SECRET_KEY
will result in an exception rather than aDeprecationWarning
. (This is accelerated from the usual deprecation path; see the Django 1.4 release notes.) - The
mod_python
request handler will be removed. Themod_wsgi
handler should be used instead. - The
template
attribute ondjango.test.client.Response
objects returned by the test client will be removed. Thetemplates
attribute should be used instead. - The
django.test.simple.DjangoTestRunner
will be removed. Instead use aunittest
-native class. The features of thedjango.test.simple.DjangoTestRunner
(including fail-fast and Ctrl-C test termination) can be provided byunittest.TextTestRunner
. - The undocumented function
django.contrib.formtools.utils.security_hash
will be removed, instead usedjango.contrib.formtools.utils.form_hmac
- The function-based generic view modules will be removed in favor of their class-based equivalents, outlined here.
- The
django.core.servers.basehttp.AdminMediaHandler
will be removed. In its place usedjango.contrib.staticfiles.handlers.StaticFilesHandler
. - The template tags library
adminmedia
and the template tag{% admin_media_prefix %}
will be removed in favor of the generic static files handling. (This is faster than the usual deprecation path; see the Django 1.4 release notes.) - The
url
andssi
template tags will be modified so that the first argument to each tag is a template variable, not an implied string. In 1.4, this behavior is provided by a version of the tag in thefuture
template tag library. - The
reset
andsqlreset
management commands will be removed. - Authentication backends will need to support an inactive user
being passed to all methods dealing with permissions.
The
supports_inactive_user
attribute will no longer be checked and can be removed from custom backends. transform()
will raise aGEOSException
when called on a geometry with no SRID value.django.http.CompatCookie
will be removed in favor ofdjango.http.SimpleCookie
.django.core.context_processors.PermWrapper
anddjango.core.context_processors.PermLookupDict
will be removed in favor of the correspondingdjango.contrib.auth.context_processors.PermWrapper
anddjango.contrib.auth.context_processors.PermLookupDict
, respectively.- The
MEDIA_URL
orSTATIC_URL
settings will be required to end with a trailing slash to ensure there is a consistent way to combine paths in templates. django.db.models.fields.URLField.verify_exists
will be removed. The feature was deprecated in 1.3.1 due to intractable security and performance issues and will follow a slightly accelerated deprecation timeframe.- Translations located under the so-called project path will be ignored during
the translation building process performed at runtime. The
LOCALE_PATHS
setting can be used for the same task by including the filesystem path to alocale
directory containing non-app-specific translations in its value. - The Markup contrib app will no longer support versions of Python-Markdown library earlier than 2.1. An accelerated timeline was used as this was a security related deprecation.
- The
CACHE_BACKEND
setting will be removed. The cache backend(s) should be specified in theCACHES
setting.
1.4¶
See the Django 1.2 release notes for more details on these changes.
CsrfResponseMiddleware
andCsrfMiddleware
will be removed. Use the{% csrf_token %}
template tag inside forms to enable CSRF protection.CsrfViewMiddleware
remains and is enabled by default.- The old imports for CSRF functionality (
django.contrib.csrf.*
), which moved to core in 1.2, will be removed. - The
django.contrib.gis.db.backend
module will be removed in favor of the specific backends. SMTPConnection
will be removed in favor of a generic email backend API.- The many to many SQL generation functions on the database backends will be removed.
- The ability to use the
DATABASE_*
family of top-level settings to define database connections will be removed. - The ability to use shorthand notation to specify a database backend
(i.e.,
sqlite3
instead ofdjango.db.backends.sqlite3
) will be removed. - The
get_db_prep_save
,get_db_prep_value
andget_db_prep_lookup
methods will have to support multiple databases. - The
Message
model (indjango.contrib.auth
), its related manager in theUser
model (user.message_set
), and the associated methods (user.message_set.create()
anduser.get_and_delete_messages()
), will be removed. The messages framework should be used instead. The relatedmessages
variable returned by the auth context processor will also be removed. Note that this means that the admin application will depend on the messages context processor. - Authentication backends will need to support the
obj
parameter for permission checking. Thesupports_object_permissions
attribute will no longer be checked and can be removed from custom backends. - Authentication backends will need to support the
AnonymousUser
class being passed to all methods dealing with permissions. Thesupports_anonymous_user
variable will no longer be checked and can be removed from custom backends. - The ability to specify a callable template loader rather than a
Loader
class will be removed, as will theload_template_source
functions that are included with the built in template loaders for backwards compatibility. django.utils.translation.get_date_formats()
anddjango.utils.translation.get_partial_date_formats()
. These functions will be removed; use the locale-awaredjango.utils.formats.get_format()
to get the appropriate formats.- In
django.forms.fields
, the constants:DEFAULT_DATE_INPUT_FORMATS
,DEFAULT_TIME_INPUT_FORMATS
andDEFAULT_DATETIME_INPUT_FORMATS
will be removed. Usedjango.utils.formats.get_format()
to get the appropriate formats. - The ability to use a function-based test runner will be removed,
along with the
django.test.simple.run_tests()
test runner. - The
views.feed()
view andfeeds.Feed
class indjango.contrib.syndication
will be removed. The class-based viewviews.Feed
should be used instead. django.core.context_processors.auth
. This release will remove the old method in favor of the new method indjango.contrib.auth.context_processors.auth
.- The
postgresql
database backend will be removed, use thepostgresql_psycopg2
backend instead. - The
no
language code will be removed and has been replaced by thenb
language code. - Authentication backends will need to define the boolean attribute
supports_inactive_user
until version 1.5 when it will be assumed that all backends will handle inactive users. django.db.models.fields.XMLField
will be removed. This was deprecated as part of the 1.3 release. An accelerated deprecation schedule has been used because the field hasn’t performed any role beyond that of a simpleTextField
since the removal ofoldforms
. All uses ofXMLField
can be replaced withTextField
.- The undocumented
mixin
parameter to theopen()
method ofdjango.core.files.storage.Storage
(and subclasses) will be removed.
1.3¶
See the Django 1.1 release notes for more details on these changes.
AdminSite.root()
. This method of hooking up the admin URLs will be removed in favor of includingadmin.site.urls
.- Authentication backends need to define the boolean attributes
supports_object_permissions
andsupports_anonymous_user
until version 1.4, at which point it will be assumed that all backends will support these options.