設定 Django Admin

開始使用 Django 管理員所需的一切都已經在 Django 的預設專案佈局中進行了設定。這包括:

# settings.py

# `django.contrib.admin` and its dependancies.
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    ...,
]

MIDDLEWARE = [
    ...
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    ...
]

TEMPLATES = [
    {
        ...,
        'OPTIONS': {
            'context_processors': [
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
                ...
            ],
        },
    },
]

關於在 Django> = 1.9 中略有不同的 urls.py 比在舊版本中要小心。

Version >= 1.9

from django.conf.urls import url
from django.contrib import admin

urlpatterns = [
    url(r'^admin/', admin.site.urls),
]

Version < 1.9

from django.conf.urls import url, include
from django.contrib import admin

urlpatterns = [
    url(r'^admin/', include(admin.site.urls)),
]

使用 include 的版本仍然可以在 Django 1.9 中使用,但已被棄用,將來會被刪除。

如果尚未完成,則必須應用基本遷移:

$ python manage.py migrate

要訪問管理員,你還必須建立一個超級使用者:

$ python manage.py createsuperuser

完成後,你可以執行你的伺服器:

$ python manage.py runserver

並訪問管理頁面 http://127.0.0.1:8000/admin/