Notes de publication de Django 4.0¶
7 décembre 2021
Bienvenue dans Django 4.0 !
Ces notes de publications couvrent les nouvelles fonctionnalités, ainsi que certaines modifications non rétrocompatibles dont il faut être au courant lors de la mise à jour depuis Django 3.2 ou des versions plus anciennes. Nous avons commencé le processus d’obsolescence de certaines fonctionnalités.
Voir le guide Mise à jour de Django à une version plus récente si vous mettez à jour un projet existant.
Compatibilité Python¶
Django 4.0 requiert Python 3.8, 3.9 ou 3.10. Nous recommandons vivement et nous ne prenons officiellement en charge que la dernière publication de chaque série.
La série Django 3.2.x est la dernière à prendre en charge Python 3.6 et 3.7.
Quoi de neuf dans Django 4.0¶
Implémentation des fuseaux horaires par défaut avec zoneinfo¶
Le module zoneinfo de la bibliothèque Python standard est dorénavant l’implémentation par défaut des fuseaux horaires dans Django.
Il s’agit de l’étape suivante de la migration depuis pytz à zoneinfo. Django 3.2 autorisait l’utilisation de fuseaux horaires autres que pytz. Django 4.0 fait de zoneinfo l’implémentation par défaut. La prise en charge de pytz est maintenant obsolète et sera supprimée dans Django 5.0.
zoneinfo fait partie de la bibliothèque standard de Python à partir de la version 3.9. Le paquet backports.zoneinfo est automatiquement installé avec Django si vous utilisez encore Python 3.8.
Le passage à zoneinfo devrait être largement transparent. La sélection du fuseau horaire actuel, la conversion d’instances de dates vers le fuseau horaire actuel dans les formulaires et gabarits, de même que les opérations sur les dates conscientes en UTC ne sont pas touchées.
Cependant, si vous travaillez avec des fuseaux horaires autres que UTC et que vous utilisez les API pytz normalize() et localize(), possiblement avec le réglage TIME_ZONE, il faudra auditer votre code, car pytz et zoneinfo ne sont pas complètement équivalentes.
Pour vous donner du temps pour un tel audit, le réglage temporaire USE_DEPRECATED_PYTZ permet de continuer à utiliser pytz durant le cycle de publication 4.x. Ce réglage sera supprimé dans Django 5.0.
De plus, un paquet pytz_deprecation_shim, créé par l’auteur de zoneinfo, peut aider à la migration à partir de pytz. Ce paquet fournit des fonctions de substitution pour vous aider à vous séparer de pytz et contient un guide de migration détaillé vous expliquant comment passer à la nouvelle API de zoneinfo.
Using pytz_deprecation_shim and the USE_DEPRECATED_PYTZ
transitional setting is recommended if you need a gradual update path.
Contraintes d’unicité basées sur des fonctions¶
Le nouveau paramètre positionnel *expressions de UniqueConstraint() permet de créer des contraintes d’unicité fonctionnelles sur la base d’expressions et de fonctions de base de données. Par exemple
from django.db import models
from django.db.models import UniqueConstraint
from django.db.models.functions import Lower
class MyModel(models.Model):
first_name = models.CharField(max_length=255)
last_name = models.CharField(max_length=255)
class Meta:
constraints = [
UniqueConstraint(
Lower("first_name"),
Lower("last_name").desc(),
name="first_last_name_unique",
),
]
Les contraintes d’unicité fonctionnelles peuvent être ajoutés aux modèles en utilisant l’option Meta.constraints.
Hacheur de mot de passe scrypt¶
Le nouveau hacheur de mot de passe scrypt est plus sûr et préféré à PBKDF2. Cependant, ce n’est pas le choix par défaut car il nécessite OpenSSL 1.1+ et plus de mémoire.
Moteur de cache Redis¶
The new django.core.cache.backends.redis.RedisCache cache backend provides
built-in support for caching with Redis. redis-py 3.0.0 or
higher is required. For more details, see the documentation on caching
with Redis in Django.
Rendu des formulaires basé sur des gabarits¶
Forms, Formsets et ErrorList sont dorénavant produits avec le moteur de gabarits pour faciliter la personnalisation. Pour les formulaires Form, référez-vous aux nouveautés render(), get_context() et template_name, alors que pour les jeux de formulaires Formset, consultez rendu des jeux de formulaires.
Fonctionnalités mineures¶
django.contrib.admin¶
Le gabarit
admin/base.htmlpossède dorénavant un nouveau blocheader(en-tête) qui contient l’en-tête du site d’administration.La nouvelle méthode
ModelAdmin.get_formset_kwargs()permet de personnaliser les arguments mot-clés transmis au constructeur d’un jeu de formulaires.La barre latérale de navigation possède maintenant une barre d’outils de filtre rapide.
La nouvelle variable de contexte
modelcontenant la classe de modèle de chaque modèle a été ajoutée à la méthodeAdminSite.each_context().Le nouvel attribut
ModelAdmin.search_help_textpermet d’indiquer un texte descriptif pour la zone de recherche.Quand l’attribut
InlineModelAdmin.verbose_name_pluralest manquant, son contenu se base dorénavant surInlineModelAdmin.verbose_name+'s'.La version intégrée de jQuery a été mise à jour de 3.5.1 vers 3.6.0.
django.contrib.admindocs¶
admindocspermet dorénavant des configurations spéciales oùROOT_URLCONFn’est pas une chaîne.La section des modèles de
admindocsaffiche maintenant aussi les propriétés en cache.
django.contrib.auth¶
Le nombre d’itération par défaut du hacheur de mot de passe PBKDF2 a été augmenté de 260’000 à 320’000.
Le nouvel attribut
LoginView.next_pageet la méthodeget_default_redirect_url()permettent de personnaliser la redirection après la connexion.
django.contrib.gis¶
La prise en charge de SpatiaLite 5 a été ajoutée.
GDALRasterpermet dorénavant de créer des matrices dans n’importe quel système de fichiers virtuel GDAL.La nouvelle classe
GISModelAdminpermet de personnaliser le composant utilisé pour les champsGeometryField. C’est l’utilisation recommandée, dans la mesure oùGeoModelAdminetOSMGeoAdminont été rendues obsolètes.
django.contrib.postgres¶
Le moteur PostgreSQL prend dorénavant en charge la connexion par un nom de service. Voir Paramètres de connexion PostgreSQL pour plus de détails.
La nouvelle opération
AddConstraintNotValidpermet de créer des contraintes d’intégrité avec PostgreSQL sans vérifier que toutes les lignes existantes satisfont la nouvelle contrainte.La nouvelle opération
ValidateConstraintpermet de valider les contraintes d’intégrité qui ont été créées avecAddConstraintNotValidsur PostgreSQL.La nouvelle expression
ArraySubquery()permet de définir des sous-requêtes pour construire des listes de valeurs avec PostgreSQL.La nouvelle expression de requête
trigram_word_similaret les expressionsTrigramWordDistance()etTrigramWordSimilarity()permettent d’utiliser la similarité de mots par trigramme.
django.contrib.staticfiles¶
ManifestStaticFilesStorageremplace dorénavant les chemins vers les références JavaScript « source map » par leur équivalent avec empreinte intégrée.Le nouvel argument
manifest_storagedeManifestFilesMixinet deManifestStaticFilesStoragepermet de personnaliser le stockage du fichier « manifest ».
Cache¶
La nouvelle API asynchrone de
django.core.cache.backends.base.BaseCachedébute le processus de compatibilité asynchrone des moteurs de cache. Lea nouvelles méthodes asynchrones sont toutes préfixées para, par ex.aadd(),aget(),aset(),aget_or_set()ouadelete_many().À l’avenir, le préfixe
asera utilisé de manière générale pour les variantes asynchrones des méthodes.
CSRF¶
La protection CSRF consulte dorénavant l’en-tête
Originquand elle existe. Pour faciliter cela, certaines modifications du réglageCSRF_TRUSTED_ORIGINSsont nécessaires.
Formulaires¶
ModelChoiceFieldinclut dorénavant la valeur fournie dans l’argumentparamsd’une erreurValidationErrorpour le message d’erreurinvalid_choice. Cela permet à des messages d’erreur personnalisés d’utiliser le substituant%(value)s.BaseFormSetproduit dorénavant les erreurs non liées à un champ avec une classe supplémentairenonformpour aider à les distinguer des erreurs spécifiques à un champ particulier.BaseFormSetpermet maintenant de contrôler le composant utilisé pour la suppression des formulaires aveccan_deleteen définissant l’attributdeletion_widgetou en surchargeant la méthodeget_deletion_widget().
Internationalisation¶
La prise en charge des traductions en malais a été ajoutée.
Vues génériques¶
DeleteViewutilise dorénavantFormMixin, permettant d’ajouter par exemple à une sous-classe deFormune case à cocher pour confirmer sa suppression. De plus, cela permet àDeleteViewde fonctionner correctement avecdjango.contrib.messages.views.SuccessMessageMixin.En accord avec le fonctionnement de
FormMixin, la suppression d’objets par les requêtes POST est traitée dansform_valid(). Les logiques personnalisées de suppression dans les méthodesdelete()surchargées doivent être déplacées dansform_valid()ou dans une méthode utilitaire partagée, selon les cas.
Journalisation¶
L’alias de la base de données utilisée dans un appel SQL est dorénavant transmise comme contexte supplémentaire avec chaque message du journaliseur django.db.backends.
Commandes d’administration¶
La commande d’administration
runserverprend désormais en charge l’option--skip-checks.Avec PostgreSQL,
dbshellaccepte dorénavant un fichier de mot de passe en paramètre.The
shellcommand now respectssys.__interactivehook__at startup. This allows loading shell history between interactive sessions. As a consequence,readlineis no longer loaded if running in isolated mode.Le nouvel attribut
BaseCommand.suppressed_base_argumentspermet de supprimer des options de commande par défaut non prises en charge dans le contenu de l’aide.Les nouvelles options
startapp --excludeetstartproject --excludepermettent d’exclure des répertoires des modèles.
Modèles¶
La nouvelle méthode
QuerySet.contains(obj)indique si le jeu de requête contient l’objet donné. La requête est effectuée de la manière la plus simple et rapide possible.Le nouvel argument
precisionde la fonction de base de donnéesRound()permet de définir le nombre de décimales à conserver pour l’arrondi.QuerySet.bulk_create()définit dorénavant la clé primaire des objets quand on l’utilise avec SQLite 3.35+.Le champ
DurationFieldprend désormais en charge la multiplication et la division par des valeurs scalaires avec SQLite.QuerySet.bulk_update()renvoie dorénavant le nombre d’objets mis à jour.Le nouvel attribut
Expression.empty_result_set_valuepermet de définir une valeur à renvoyer lorsque la fonction est appliquée à un jeu de résultat vide.The
skip_lockedargument ofQuerySet.select_for_update()is now allowed on MariaDB 10.6+.Les expressions
Lookuppeuvent maintenant être utilisées dans les annotations, les agrégats et directement dans les filtres des requêtesQuerySet.Le nouvel argument default des agrégats intégrés permet de définir une valeur à renvoyer lorsque le jeu de requête (ou le groupement) ne contient aucune ligne, à la place de
None.
Requêtes et réponses¶
L’intergiciel
SecurityMiddlewareajoute dorénavant l’en-tête ref:Cross-Origin Opener Policy <cross-origin-opener-policy> avec une valeur de'same-origin'pour empêcher les fenêtres popup d’origine croisée de partager le même contexte de navigation. Vous pouvez empêcher l’ajout de cet en-tête en définissant le réglageSECURE_CROSS_ORIGIN_OPENER_POLICYàNone.
Signaux¶
The new
stdoutargument forpre_migrate()andpost_migrate()signals allows redirecting output to a stream-like object. It should be preferred oversys.stdoutandprint()when emitting verbose output in order to allow proper capture when testing.
Gabarits¶
Le filtre de gabarit
floatformatpermet dorénavant d’utiliser le suffixeupour forcer la désactivation de la régionalisation.
Tests¶
Le nouvel argument
serialized_aliasesdedjango.test.utils.setup_databases()détermine quels alias de tests de bases de donnéesDATABASESdoivent voir leur état sérialisé pour permettre l’utilisation de la fonctionnalité serialized_rollback.The
test --bufferoption now supports parallel tests.The new
loggerargument toDiscoverRunnerallows a Python logger to be used for logging.La nouvelle méthode
DiscoverRunner.log()fournit une façon de journaliser les messages en utilisantDiscoverRunner.loggerou en affichant dans la console si cette dernière n’est pas définie.DiscoverRunnercan now execute tests in a random order using thetest --shuffleoption.L’option
test --parallelprend dorénavant en charge la valeurautopour lancer un processus de tests pour chaque cœur de processeur.TestCase.captureOnCommitCallbacks()capture dorénavant les nouvelles fonctions de rappel ajoutées lors de l’exécution des fonctions de rappeltransaction.on_commit().
Changements incompatibles avec les anciennes versions dans Django 4.0¶
API de moteur de base de données¶
Cette section décrit des modifications qui pourraient être nécessaires dans des moteurs de base de données tiers.
Les méthodes
DatabaseOperations.year_lookup_bounds_for_date_field()etyear_lookup_bounds_for_datetime_field()acceptent désormais l’argument facultatifiso_yearafin de prendre en charge les limites pour les années de numérotation de semaines ISO-8601.Le deuxième argument des méthodes
DatabaseSchemaEditor._unique_sql()et_create_unique_sql()s’appelle maintenantfieldsau lieu decolumns.
django.contrib.gis¶
La prise en charge de PostGIS 2.3 a été supprimée.
La prise en charge de GDAL 2.0 et GEOS 3.5 a été supprimée.
Abandon de la prise en charge de PostgreSQL 9.6¶
La prise en charge amont de PostgreSQL 9.6 se termine en novembre 2021. Django 4.0 prend en charge PostgreSQL 10 et plus récent.
De plus, la version minimale prise en charge de psycopg2 est passée de 2.5.4 à 2.8.4, car psycopg2 2.8.4 est la première version à prendre en charge Python 3.8.
Abandon de la prise en charge de Oracle 12.2 et 18c¶
La prise en charge de Oracle 12.2 par le projet amont se termine en mars 2022 et en juin 2021 pour Orcale 18c. Django 3.2 sera pris en charge jusqu’en avril 2024. Django 4.0 prend officiellement en charge Oracle 19c.
Modifications de CSRF_TRUSTED_ORIGINS¶
Modification de format¶
Les valeurs dans le réglage CSRF_TRUSTED_ORIGINS doivent inclure le protocole (par ex. 'http://' ou 'https://') et non plus uniquement le nom d’hôte.
De même, les valeurs qui commencent par un point doivent dorénavant aussi inclure un astérisque avant le point. Par exemple, changez '.exemple.com' en 'https://*.exemple.com'.
Un contrôle système détecte les changements nécessaires.
Sa configuration peut maintenant être requise¶
Comme la protection CSRF consulte maintenant l’en-tête Origin, il se peut que vous deviez définir CSRF_TRUSTED_ORIGINS, particulièrement si vous autorisez les requêtes à partir de sous-domaines en définissant CSRF_COOKIE_DOMAIN (ou SESSION_COOKIE_DOMAIN si CSRF_USE_SESSIONS est activé) à une valeur commençant par un point.
SecurityMiddleware ne définit plus l’en-tête X-XSS-Protection¶
L’intergiciel SecurityMiddleware ne définit plus l’en-tête X-XSS-Protection quand le réglage SECURE_BROWSER_XSS_FILTER vaut True. Ce réglage est supprimé.
La plupart des navigateurs modernes ne considèrent plus l’en-tête HTTP X-XSS-Protection. Vous pouvez utiliser plutôt Content-Security-Policy sans autoriser les scripts 'unsafe-inline'.
Si vous souhaitez prendre en charge les anciens navigateurs et définir cet en-tête, utilisez cette ligne dans un intergiciel personnalisé
response.headers.setdefault("X-XSS-Protection", "1; mode=block")
Modifications de l’autodétecteur de migrations¶
L’autodétecteur de migrations utilise dorénavant les états de modèles au lieu de classes de modèles. De plus, les opérations de migration pour les champs ForeignKey et ManyToManyField ne définissent plus les attributs qui n’ont pas été transmis à ces champs lors de leur initialisation.
Comme effet de bord, le lancement de makemigrations pourrait générer des opérations AlterField neutres pour les champs ManyToManyField et ForeignKey dans certains cas.
Modifications de DeleteView¶
DeleteView utilise dorénavant FormMixin pour gérer les requêtes POST. En conséquence, tout logique personnalisée de suppression dans les méthodes delete() doivent être déplacées dans form_valid(), ou dans une autre méthode utilitaire partagée, si nécessaire.
Table and column naming scheme changes on Oracle¶
Django 4.0 inadvertently changed the table and column naming scheme on Oracle.
This causes errors for models and fields with names longer than 30 characters.
Unfortunately, renaming some Oracle tables and columns is required. Use the
upgrade script in 33789 to generate RENAME
statements to change naming scheme.
Divers¶
La prise en charge de
cx_Oracle< 7.0 a été abandonnée.Pour permettre de servir un site Django sur un sous-chemin sans modifier la valeur de
STATIC_URL, la barre oblique initiale est supprimée de ce réglage (dorénavant'static/') dans le gabaritstartprojectpar défaut.La méthode
AdminSitepour la vueindexdu site d’administration n’est plus décorée parnever_cachelorsqu’on y accède directement, sans passer par la propriété recommandéeAdminSite.urlsou par la méthodeAdminSite.get_urls().Les opérations non prises en charge d’un jeu de requête segmenté produisent une erreur
TypeErrorau lieu deAssertionError.La fonction non documentée
django.test.runner.reorder_suite()a été renommée enreorder_tests(). Elle accepte dorénavant une structure itérable de tests plutôt qu’une suite de tests, et renvoie un itérateur de tests.L’appel à
FileSystemStorage.delete()avec un paramètrenamevide produit maintenant une exceptionValueErrorau lieu deAssertionError.L’appel à
EmailMultiAlternatives.attach_alternative()ouEmailMessage.attach()avec des valeurs de paramètrescontentoumimetypenon valables produisent maintenant une exceptionValueErrorau lieu deAssertionError.assertHTMLEqual()ne considère plus un attribut non booléen sans valeur comme égal à un attribut avec les mêmes nom et valeur.Les tests dont le chargement échoue, par exemple en raison d’erreurs de syntaxe, correspondent maintenant toujours lorsqu’on utilise l’option
test --tag.La fonction non documentée
django.contrib.admin.utils.lookup_needs_distinct()a été renommée enlookup_spawns_duplicates().La méthode non documentée
HttpRequest.get_raw_uri()a été supprimée. La méthodeHttpRequest.build_absolute_uri()pourrait être une alternative appropriée.L’argument
objectdes méthodes non documentéesModelAdmin.log_addition(),log_change()etlog_deletion()a été renommé enobj.RssFeed,Atom1Feedet leurs sous-classes émettent désormais les éléments sans contenu sous forme de balises autofermées.NodeList.render()ne force plus le résultat de la méthoderender()pour les nœuds individuels à des chaînes.Node.render()doit toujours renvoyer une chaîne comme sa documentation le demande.La propriété
where_classdedjango.db.models.sql.query.Queryainsi que l’argumentwhere_classde la méthode privéeget_extra_restriction()deForeignObjectetForeignObjectRelsont supprimées. Si nécessaire, initialisez un nœuddjango.db.models.sql.where.WhereNodeà la place.L’argument
filter_clausede la méthode non documentéeQuery.add_filter()a été remplacé par deux arguments positionnelsfilter_lhsetfilter_rhs.CsrfViewMiddlewareutilise dorénavantrequest.META['CSRF_COOKIE_NEEDS_UPDATE']en lieu et place derequest.META['CSRF_COOKIE_USED'],request.csrf_cookie_needs_resetetresponse.csrf_cookie_setpour détecter si le cookie CSRF doit être envoyé. Il s’agit d’une API privée et non documentée.La constante non documentée
TRANSLATOR_COMMENT_MARKa été déplacée dedjango.template.baseversdjango.utils.translation.template.L’argument
real_appsde la méthode non documentéedjango.db.migrations.state.ProjectState.__init__()doit dorénavant être un ensemblesetquand il est défini.Les composants
RadioSelectetCheckboxSelectMultiplesont dorénavant produits dans des balises<div>pour qu’ils soient annoncés de manière plus concise par les lecteurs d’écran. Si vous voulez revenir au comportement précédent, surchargez le gabarit du composant par le gabarit qui était utilisé dans Django 3.2.Le filtre de gabarit
floatformatne dépend plus du réglageUSE_L10Net renvoie toujours un résultat régionalisé. Utilisez le suffixeupour désactiver la régionalisation.La valeur par défaut du réglage
USE_L10Nest dorénavantTrue. Consultez la section sur la régionalisation ci-dessus pour plus de détails.As part of the move to zoneinfo,
django.utils.timezone.utcis changed to aliasdatetime.timezone.utc.La version minimum de
asgirefprise en charge est passée de 3.3.2 à 3.4.1.
Fonctionnalités rendues obsolètes dans Django 4.0¶
Utilisation des fuseaux horaires pytz¶
Dans le contexte du passage à zoneinfo, l’utilisation des fuseaux horaires pytz est obsolète.
En conséquence, les arguments is_dst des éléments suivants sont aussi obsolètes :
La prise en charge de pytz sera supprimée dans Django 5.0.
Prise en charge des fuseaux horaires¶
Afin de respecter les bonnes pratiques, la valeur par défaut du réglage USE_TZ a été modifiée de False à True, et la prise en charge des fuseaux horaires sera activée par défaut dans Django 5.0.
Notez que le fichier settings.py créé par défaut par django-admin startproject définit USE_TZ = True depuis Django 1.4.
Dans l’intervalle, vous pouvez définir USE_TZ à False dans vos réglages de projet si vous n’en voulez pas.
Régionalisation¶
Afin de respecter les bonnes pratiques, la valeur par défaut du réglage USE_L10N a été modifiée de False à True.
De plus, USE_L10N est obsolète à partir de cette version. Dès Django 5.0, les dates et les nombres seront affichés par défaut en fonction de la langue active.
Django continue d’appliquer la balise {% localize %} et les filtres localize/ unlocalize.
Divers¶
Le réglage de test
SERIALIZEest obsolète car il peut être déduit dedatabasesavec l’option serialized_rollback activée.Le module non documenté
django.utils.baseconvest obsolète.Le module non documenté
django.utils.datetime_safeest obsolète.Le protocole par défaut pour les plans de site construits en dehors du contexte de la requête changera de
'http'à'https'dans Django 5.0.L’argument
extra_testsdeDiscoverRunner.build_suite()et deDiscoverRunner.run_tests()est obsolète.Dans Django 5.0, les agrégats
ArrayAgg,JSONBAggetStringAggrenverrontNonelorsqu’il n’y a aucune ligne au lieu de respectivement[],[]et''. Si vous avez besoin du comportement précédent, définissez explicitement l’argumentdefaultàValue([]),Value('[]')ouValue('').Les classes
django.contrib.gis.admin.GeoModelAdminetOSMGeoAdminsont obsolètes, Utilisez à la placeModelAdminouGISModelAdmin.Comme le rendu des formulaires utilise dorénavant le moteur de gabarits, la méthode utilitaire et non documentée
BaseForm._html_output()est obsolète.La possibilité de renvoyer une chaîne
strà partir deErrorListetErrorDictest obsolète. Il est attendu que ces méthodes renvoient un objetSafeString.
Fonctionnalités supprimées dans 4.0¶
Ces fonctionnalités ont atteint la fin de leur cycle d’obsolescence et sont supprimées dans Django 4.0.
Voir Fonctionnalités rendues obsolètes dans Django 3.0 pour les détails de ces changements, ainsi que pour savoir comment supprimer l’utilisation de ces fonctionnalités.
django.utils.http.urlquote(),urlquote_plus(),urlunquote()eturlunquote_plus()ont été supprimées.django.utils.encoding.force_text()etsmart_text()ont été supprimées.django.utils.translation.ugettext(),ugettext_lazy(),ugettext_noop(),ungettext()etungettext_lazy()ont été supprimées.django.views.i18n.set_language()ne définit plus la langue de l’utilisateur dansrequest.session(clé_language).alias=Noneest obligatoire dans la signature des sous-classes dedjango.db.models.Expression.get_group_by_cols().django.utils.text.unescape_entities()a été supprimée.django.utils.http.is_safe_url()a été supprimée.
Voir Fonctionnalités rendues obsolètes dans Django 3.1 pour les détails de ces changements, ainsi que pour savoir comment supprimer l’utilisation de ces fonctionnalités.
Le réglage
PASSWORD_RESET_TIMEOUT_DAYSa été supprimé.L’expression de requête
isnulln’accepte plus de valeurs non booléennes dans sa partie droite.La classe d’exception
django.db.models.query_utils.InvalidQuerya été supprimée.Le point d’entrée
django-admin.pya été supprimé.La méthode
HttpRequest.is_ajax()a été supprimée.La prise en charge du format de codage des cookies d’avant Django 3.1 utilisé par
django.contrib.messages.storage.cookie.CookieStoragea été supprimée.La prise en charge des jetons de réinitialisation des mots de passe d’avant Django 3.1 dans le site d’administration (qui utilise l’algorithme de hachage SHA-1) a été supprimée.
La prise en charge du format de codage des sessions d’avant Django 3.1 a été supprimée.
La prise en charge des signatures
django.core.signing.Signerd’avant Django 3.1 (utilisant l’algorithme de hachage SHA-1) a été supprimée.La prise en charge des signatures
django.core.signing.dumps()d’avant Django 3.1 (utilisant l’algorithme de hachage SHA-1) a été supprimée dansdjango.core.signing.loads().La prise en charge des sessions d’utilisateurs d’avant Django 3.1 (utilisant l’algorithme de hachage SHA-1) a été supprimée.
L’argument
get_responsededjango.utils.deprecation.MiddlewareMixin.__init__()est obligatoire et n’accepte plusNone.L’argument
providing_argsdedjango.dispatch.Signala été supprimé.Le paramètre
lengthdedjango.utils.crypto.get_random_string()est obligatoire.Le message
listdeModelMultipleChoiceFielda été supprimé.La prise en charge de la transmission d’alias de colonnes bruts à
QuerySet.order_by()a été supprimée.Le champ de modèle
NullBooleanFielda été supprimé, sauf pour la prise en charge des migrations historiques.django.conf.urls.url()a été supprimée.Le champ de modèle
django.contrib.postgres.fields.JSONFielda été supprimé, sauf pour la prise en charge des migrations historiques.django.contrib.postgres.fields.jsonb.KeyTransformetdjango.contrib.postgres.fields.jsonb.KeyTextTransformont été supprimées.django.contrib.postgres.forms.JSONFielda été supprimé.Les balises de gabarit
{% ifequal %}et{% ifnotequal %}ont été supprimées.Le réglage temporaire
DEFAULT_HASHING_ALGORITHMa été supprimé.