Accueil🇫🇷Chercher

Django (framework)

Django est un framework web open source en Python. Il a pour but de rendre le développement d'applications web simple et basé sur la réutilisation de code. Développé en 2003 pour le journal local de Lawrence (État du Kansas, aux États-Unis), Django a été publié sous licence BSD à partir de .

Django
Description de l'image Django logo.svg.
Description de cette image, également commentée ci-après
Page par défaut de Django.

Depuis , la Django Software Foundation s'occupe du développement et de la promotion du framework. En plus de cette promotion régulière, des conférences entre développeurs et utilisateurs de Django sont organisées deux fois par an depuis 2008. Nommées DjangoCon, une se déroule en Europe et l'autre aux États-Unis.

Plusieurs sites grand public sont désormais fondés sur Django, dont Pinterest[3] et Instagram[4] au moins en 2011 ou encore Mozilla[5].

Principes

Capture d'Ă©cran de l'interface d'administration.

Django est un framework qui s'inspire du principe MVC ou MTV (la vue est gérée par un gabarit) composé de trois parties distinctes :

  1. Un langage de gabarits flexible qui permet de générer du HTML, XML ou tout autre format texte ;
  2. Un contrôleur fourni sous la forme d'un « remapping » d'URL à base d'expressions rationnelles ;
  3. Une API d'accès aux données est automatiquement générée par le framework compatible CRUD. Inutile d'écrire des requêtes SQL associées à des formulaires, elles sont générées automatiquement par l'ORM.

En plus de l'API d'accès aux données, une interface d'administration fonctionnelle est générée depuis le modèle de données. Un système de validation des données entrées par l'utilisateur est également disponible et permet d'afficher des messages d'erreur automatiques.

Sont Ă©galement inclus :

  • un serveur web lĂ©ger permettant de dĂ©velopper et tester ses applications en temps rĂ©el sans dĂ©ploiement ;
  • un système Ă©laborĂ© de traitement des formulaires muni de widgets permettant d'interagir entre du HTML et une base de donnĂ©es. De nombreuses possibilitĂ©s de contrĂ´les et de traitements sont fournies ;
  • un framework de cache web pouvant utiliser diffĂ©rentes mĂ©thodes (MemCached, système de fichier, base de donnĂ©es, personnalisĂ©) ;
  • le support de classes intermĂ©diaires (intergiciel) qui peuvent ĂŞtre placĂ©es Ă  des stades variĂ©s du traitement des requĂŞtes pour intĂ©grer des traitements particuliers (cache, internationalisation, accès…) ;
  • une prise en charge complète d'Unicode.

Django peut être considéré comme une boîte à outils où chaque module peut fonctionner de façon indépendante.

Un exemple de cette modularité est la plate-forme de développement Google App Engine, où l'ORM de base a été remplacé par une API sur les BigTable de Google. Guido Van Rossum, le créateur du langage Python, a activement participé à cette plate-forme.

Histoire

Le framework a été originellement développé pour un journal local de la ville de Lawrence, dans le Kansas, à partir de 2003, par Adrian Holovaty et Simon Willison (en)[6] - [7] - [8]. L'idée d'origine du framework était de permettre de développer des sites web complets, interfacés avec une base de données, dans un laps de temps très court[8]. Le but de Django à l'origine est de répondre aux contraintes des journalistes : l'administration générée par le framework permet ainsi un développement aisé de fonctionnalités axé « contenu ». Le framework se voulait également accessible, afin d'éviter le recrutement d'experts en développement pour les journaux[8]. Le framework a été nommé ainsi en souvenir de Django Reinhardt, musicien de jazz[6] - [7].

En 2005, l'agence de presse décide de publier le framework au public, sous la licence BSD[6]. C'est depuis cette ouverture que sa notoriété augmente. Il sera repris plus tard, en par la fondation Django Software[9] qui maintient encore aujourd'hui la communauté et le développement du framework. À la suite de cette reprise, la version 1.0 du framework sort quelques mois plus tard[10]. À partir de cette version, les mises à jour se stabilisent à une version majeure annuelle.

En , une politique de publication est mise au point, pour sortir une nouvelle version tous les huit mois, et une version avec un support étendu tous les deux ans[11]. À cette occasion, il est annoncé que le support de Python 2 ne serait probablement assuré que jusqu'à la version 1.11, qui sera la dernière de la branche 1.x[11].

Historique des versions

Après la mise à disposition public par le journal Lawrence, le développement open-source de Django commence à la version 0.90. Les premières versions sont numérotés jusqu'à 0.96 et ont pour but de stabiliser l'interface de programmation principale, et chaque version apporte donc de nombreuses modifications dans la façon d'utiliser le framework[12]. La sortie de la version 1.0 marque le début de la maturité du framework, avec une interface qui se veut compatible avec les versions futures[13]. Un guide est publié pour permettre aux utilisateurs de migrer de Django 0.96 à 1.0[14].

Pendant le développement de la branche « Django 1.x », le cycle de développement n'a pas de rythme défini mais respecte la convention de nommage de version suivante[15] :

  • Chaque nouvelle version majeure est numĂ©rotĂ©e 1.x.0, oĂą x est incrĂ©mentĂ© par rapport Ă  la version prĂ©cĂ©dente et apporte de nouvelles fonctionnalitĂ©s et Ă©ventuellement des incompatibilitĂ©s avec les versions prĂ©cĂ©dentes ;
  • Des correctifs de sĂ©curitĂ© et de bugs sont fournis sous la forme 1.x.y, sans ajouter de nouvelles fonctionnalitĂ©s et se veut rĂ©trocompatible.

En , à la suite d'un sondage et des discussions entre développeurs, une feuille de route est formalisée, avec un rythme de publication facilitant la maintenance des projets et des applications tierces[11]. Une nouvelle version du framework est désormais publiée tous les huit mois, avec une long term support (LTS) tous les trois versions, c'est-à-dire tous les deux ans. Ces versions bénéficient de mises à jour de sécurité pendant une période d'au moins trois ans[16]. La numérotation des versions est par conséquent revue, permettant une maintenance plus aisée pour les utilisateurs du framework : la version suivant une LTS entraînera la suppression des éléments dépréciés depuis la précédente LTS et commencera un nouveau cycle de version majeure[11] - [17]. Ainsi, à partir de Django 2.0, les versions seront 2.1, 2.2 LTS, 3.0, 3.1, 3.2 LTS, etc.

Code des couleurs
Rouge Ancienne version, non supportée
Vert Version actuelle ou supportée
Bleu Version Ă  venir
Version majeureVersion mineureDate de sortieVersion Python minimumNotes
Open Source - 2.3 Mise Ă  disposition public de Django par Lawrence.
Version « 0 » 0.90 2.3
0.91 2.3
0.95 2.3 Notes de version 0.95
0.96 2.3 Notes de version 0.96
Version 1 1.0 2.3 Notes de version 1.0
1.1 2.3 Notes de version 1.1
1.2 2.4 Notes de version 1.2
1.3 2.4 Notes de version 1.3
1.4 LTS 2.5 Notes de version 1.4, support jusqu'au [18]
1.5 2.6.5[19] Notes de version 1.5, support de Python 3
1.6 2.6.5 Notes de version 1.6
1.7 2.7 Notes de version 1.7
1.8 LTS 2.7 Notes de version 1.8
1.9 2.7 et 3.4 Notes de version 1.9
1.10 2.7 et 3.4 Notes de version 1.10
1.11 LTS 2.7 et 3.4 Notes de version 1.11, dernière version à supporter Python 2
Version 2 2.0 3.4 Notes de version 2.0
2.1 3.5 Notes de version 2.1
2.2 LTS 3.5 Notes de version 2.2
Version 3 3.0 3.6 Notes de version 3.0
3.1 3.6 Notes de version 3.1
3.2 LTS 3.6 Notes de version 3.2
Version 4 4.0 3.8 Notes de version 4.0
4.1 3.8 Notes de version 4.1
4.2 LTS

Chacune de ces versions est, ou a été, mise à jour durant son support, via des micro-releases[20]. Par exemple, la version 1.2 a eu sept mises à jour, corrigeant de nombreux bugs et failles de sécurité. Ces versions n'ajoutent pas de fonctionnalités et garantissent une compatibilité identique à la version mineure associée (sauf cas particuliers).

Forces et faiblesses de Django

Les forces

  • Les vues gĂ©nĂ©riques : il s'agit de vues permettant de traiter les cas les plus courants du dĂ©veloppement web de manière très simple. Elles permettent par exemple de lister des objets avec une gestion de la pagination, de lister des objets organisĂ©s par date avec des URL du type (annĂ©e)/(mois)/(jour)/Ă©lĂ©ment Ă  afficher. Plus d'informations sont disponibles dans la documentation sur les vues gĂ©nĂ©riques.
  • Le système d'authentification
  • La crĂ©ation de pages statiques
  • La documentation : Django possède une très bonne documentation en anglais, dont une partie, l'API stabilisĂ©e, est traduite en français[21]. Cette documentation, au format ReStructuredText (ReST), est compatible avec le projet Sphinx.
  • Les exceptions : les exceptions et backtraces Python sont bien gĂ©rĂ©es dans Django et apparaissent dans les pages d'erreur 500, en mode dĂ©bogage. On peut avoir une bonne idĂ©e des variables d'environnement et du code ayant provoquĂ© l'exception. Des efforts sont menĂ©s pour inclure d'autres outils comme la barre de dĂ©bogage de Symfony (Django Debug Toolbar).

Les faiblesses

  • L'AJAX : Django en tant que framework ne permet pas, seul, l'intĂ©gration d'AJAX cĂ´tĂ© client web. C'est un choix de l'Ă©quipe de dĂ©veloppement qui prĂ©fère laisser Ă  l'utilisateur le choix de la bibliothèque AJAX Ă  combiner avec Django (MooTools, Prototype, MochiKit (en), jQuery, dojo, ext, etc.)[22].

Communauté

Plusieurs organisations gravitent autour du framework afin d'aider les utilisateurs à le prendre en main. Il existe notamment les DjangoCon, événement composé de conférences et d'ateliers autour du framework, mais également des associations afin d'attirer les personnes rarement impliquées dans l'informatique. C'est le cas de Django Girls, qui invite les femmes à venir s'initier à Django et au Python de manière générale.

DjangoCon

Des conférences sont tenues tous les ans pour les développeurs et utilisateurs de Django, appelées « DjangoCon ». Des événements distincts ont lieu aux États-Unis et en Europe. Ces événements sont composés de plusieurs parties :

  • les confĂ©rences : pendant deux Ă  trois jours, des bĂ©nĂ©voles prĂ©sentent un point particulier du framework, des usages spĂ©cifiques, un retour d'expĂ©rience, etc. ;
  • les sprints : les jours suivant les confĂ©rences, des sessions de programmation sont organisĂ©es, pour tous niveaux, afin de parfaire sa maĂ®trise du framework. Des tutoriaux sont mis en place pour initier les nouveaux utilisateurs.

En Europe

Le lieu de l'événement change chaque année, afin de pouvoir toucher le maximum de personnes sur plusieurs années. Des aides sont également fournies pour les personnes en difficulté financière, voulant tout de même participer, grâce aux dons des entreprises partenaires de l'événement ainsi que des autres participants. Regroupant plus de 300 développeurs tous les ans[23], l'événement accueille aussi bien des Européens que des personnes des autres continents.

À partir de 2015, les DjangoCon Europe mettent l'accent sur la diversité, en incitant les personnes minoritaires dans le domaine de l'informatique (femmes, handicapés, personnes âgées) à venir participer et partager leurs connaissances[24]. Pour son édition de 2016, l'organisation se targue d'avoir reçu 48 % de propositions de conférences venant de femmes et qu'après sélection 54 % des conférenciers seront des femmes[25].

Voir aussi

Articles connexes

Liens externes

Bibliographie

Notes et références

  1. « http://www.djangobook.com/en/2.0/chapter01.html#django-s-history »
  2. « Release 4.2.2 », (consulté le )
  3. What technologies were used to make Pinterest?
  4. What Powers Instagram: Hundreds of Instances, Dozens of Technologies
  5. Code source de mozilla.org
  6. (en) « Introduction to Django : Django’s History », sur Django Book (consulté le )
  7. Maxime Lorant et Mathieu Xhonneux, « Créez vos applications web avec Django : Qu'est-ce que Django », sur openclassroom.com (consulté le )
  8. (en) Karen Dillon, « Lawrence-born Django, which revolutionized website construction, celebrating its 10th anniversary », sur Lawrence Journal-World, (consulté le )
  9. Announcing the Django Software Foundation, consulté le 13 août 2012
  10. Django 1.0 released!, consulté le 13 août 2012
  11. (en) Tim Graham, « Django's Roadmap », sur djangoproject.com, (consulté le )
  12. (en) « Django version 0.95 release notes », sur djangoproject.com, (consulté le )
  13. (en) « 1.0 release notes », sur djangoproject.com (consulté le )
  14. (en) « 1.0 porting guide », sur djangoproject.com (consulté le )
  15. (en) « Django’s release process (Django 1.8) », sur djangoproject.com (consulté le )
  16. Long Term Support releases sur la page "Django’s release process"
  17. (en) « Django’s release process - Deprecation policy », sur djangoproject.com (consulté le )
  18. (en) Tim Graham, « Django 1.8 released », sur djangoproject.com, (consulté le )
  19. Django's future, and Python 3
  20. (en) « Micro releases sur la page « Django’s release process » », sur djangoproject.com
  21. « Django », sur Django Project (consulté le ).
  22. (en) Page traitant de AJAX sur le Wiki du projet
  23. Page Sponsorship du site officiel : « This event will be attended by over 300 Django developers from across the world. »
  24. (en) « Diversity », sur 2015.djangocon.eu (consulté le )
  25. Ola Sitarska, « Announcing the results of Call for Speakers! », sur DjangoCon Europe, (consulté le ).
Cet article est issu de wikipedia. Text licence: CC BY-SA 4.0, Des conditions supplémentaires peuvent s’appliquer aux fichiers multimédias.