Django - Interface d'administration

Django fournit une interface utilisateur prête à l'emploi pour les activités administratives. Nous savons tous à quel point une interface d'administration est importante pour un projet Web. Django génère automatiquement une interface utilisateur d'administration en fonction de vos modèles de projet.

Démarrage de l'interface d'administration

L'interface d'administration dépend du module django.countrib. Pour que cela fonctionne, vous devez vous assurer que certains modules sont importés dans les tuples INSTALLED_APPS et MIDDLEWARE_CLASSES du fichier myproject / settings.py.

Pour INSTALLED_APPS, assurez-vous d'avoir -

INSTALLED_APPS = (
   'django.contrib.admin',
   'django.contrib.auth',
   'django.contrib.contenttypes',
   'django.contrib.sessions',
   'django.contrib.messages',
   'django.contrib.staticfiles',
   'myapp',
)

Pour 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',
)

Avant de lancer votre serveur, pour accéder à votre interface d'administration, vous devez lancer la base de données -

$ python manage.py migrate

syncdb créera les tables ou collections nécessaires en fonction de votre type de base de données, nécessaire à l'exécution de l'interface d'administration. Même si vous n'avez pas de superutilisateur, vous serez invité à en créer un.

Si vous avez déjà un superutilisateur ou que vous l'avez oublié, vous pouvez toujours en créer un en utilisant le code suivant -

$ python manage.py createsuperuser

Maintenant, pour démarrer l'interface d'administration, nous devons nous assurer que nous avons configuré une URL pour notre interface d'administration. Ouvrez le myproject / url.py et vous devriez avoir quelque chose comme -

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)),
)

Maintenant, lancez simplement le serveur.

$ python manage.py runserver

Et votre interface d'administration est accessible à l'adresse: http://127.0.0.1:8000/admin/

Une fois connecté à votre compte superutilisateur, vous verrez l'écran suivant -

Cette interface vous permettra d'administrer les groupes et les utilisateurs Django, ainsi que tous les modèles enregistrés dans votre application. L'interface vous donne la possibilité d'effectuer au moins les opérations "CRUD" (Créer, Lire, Mettre à jour, Supprimer) sur vos modèles.