我刚刚从2移植到Python3,并将Django从1.7升级到2.0(我知道有很多变化)。我正在使用Heroku托管应用程序。
当我在本地运行heroku或仅使用manage.py runserver在本地运行应用程序时,应用程序会加载,但导航到/ admin页面会出现错误:
Page not found (404)
Request Method: GET
Request URL: http://127.0.0.1:5000/admin
Using the URLconf defined in loowatt.urls, Django tried these URL patterns, in this order:
write/
admin/
^$ [name='index']
The current path, admin, didn't match any of these.
我的新app.urls.py看起来像这样:
1 from django.contrib import admin
2 from django.urls import include, path
3
4 from . import views
5
6 urlpatterns = [
7 path('write/', views.write),
8 path('admin/', admin.site.urls),
9 path('', include('units.urls')),
10 ]
并且我的设置具有所有与管理员设置正确的中间件和上下文处理器:
21 INSTALLED_APPS = [
22 'django.contrib.admin',
23 'django.contrib.auth',
24 'django.contrib.contenttypes',
25 'django.contrib.sessions',
26 'django.contrib.messages',
27 'units.apps.UnitsConfig',
28 # Disable Django's own staticfiles handling in favour of WhiteNoise, for
29 # greater consistency between gunicorn and `./manage.py runserver`. See:
30 # http://whitenoise.evans.io/en/stable/django.html#using-whitenoise-in-development
31 # 'whitenoise.runserver_nostatic',
32 'django.contrib.staticfiles',
33 'import_export',
34 'rangefilter',
35 ]
37 MIDDLEWARE_CLASSES = [
38 'django.middleware.security.SecurityMiddleware',
39 'whitenoise.middleware.WhiteNoiseMiddleware',
40 'django.contrib.sessions.middleware.SessionMiddleware',
41 'django.middleware.common.CommonMiddleware',
42 'django.middleware.csrf.CsrfViewMiddleware',
43 'django.contrib.auth.middleware.AuthenticationMiddleware',
44 'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
45 'django.contrib.messages.middleware.MessageMiddleware',
46 'django.middleware.clickjacking.XFrameOptionsMiddleware',
47 ]
53 TEMPLATES = [
54 {
55 'BACKEND': 'django.template.backends.django.DjangoTemplates',
56 'DIRS': [],
57 'APP_DIRS': True,
58 'OPTIONS': {
59 'context_processors': [
60 'django.template.context_processors.debug',
61 'django.template.context_processors.request',
62 'django.contrib.auth.context_processors.auth',
63 'django.contrib.messages.context_processors.messages',
64 ],
65 'debug': DEBUG,
66 },
67 },
68 ]
任何人对下一步如何使它正常工作有任何想法吗?
答案 0 :(得分:1)
您尚未从旧式中间件MIDDLEWARE_CLASSES
切换到新式中间件MIDDLEWARE
。之所以会得到404,是因为您的项目默认情况下为MIDDLEWARE = []
,因此没有发生添加斜杠的重定向(例如/admin
->`/ admin /))。
请注意,Django 1.7到2.0是 big 跳转。您可能会发现更容易先通过1.8和1.11(这是LTS并仍受支持)。在这种情况下,Django 1.11支持MIDDLEWARE_CLASSES
和MIDDLEWARE
,因此您可以使用MIDDLEWARE_CLASSES
在Django 1.11上运行您的应用程序,切换到MIDDLEWARE
来修复弃用警告,并那么您可以更好地升级到Django 2.0。
请注意,您仍可以在Django 2.0中使用url()
,因此在项目的其余部分正常工作之前,无需重写URL模式即可使用path()
。