Django URLResolver error

Я пытаюсь разместить приложение Django на сервере Windows, используя IIS, используя wfastcgi.

После создания нового проекта Django с помощью django-admin.py startproject foo, страница администратора открывается нормально, когда я запускаю ее с сервером django python manage.py runserver,

Однако, когда я пытаюсь получить к нему доступ через 127.0.0.1/foo, я получаю сообщение об ошибке Django 404:

Используя URLconf, определенный в foo.urls, Django попробовал эти шаблоны URL в следующем порядке:

админ /

Текущий путь, foo, не соответствует ни одному из них.

Файл журнала показывает, что это ошибка URLResolver. Следующий файл журнала

2018-06-11 17:42:19,210 django.template DEBUG    Exception while resolving variable 'name' in template 'unknown'.
Traceback (most recent call last):
  File "D:\Python_venvs\foo\lib\site-packages\django\core\handlers\exception.py", line 35, in inner
    response = get_response(request)
  File "D:\Python_venvs\foo\lib\site-packages\django\core\handlers\base.py", line 113, in _get_response
    resolver_match = resolver.resolve(request.path_info)
  File "D:\Python_venvs\foo\lib\site-packages\django\urls\resolvers.py", line 523, in resolve
    raise Resolver404({'tried': tried, 'path': new_path})
django.urls.exceptions.Resolver404: {'tried': [[<URLResolver <URLPattern list> (admin:admin) 'admin/'>]], 'path': 'foo/'}

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "D:\Python_venvs\foo\lib\site-packages\django\template\base.py", line 835, in _resolve_lookup
    current = current[bit]
TypeError: 'URLResolver' object is not subscriptable

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "D:\Python_venvs\foo\lib\site-packages\django\template\base.py", line 843, in _resolve_lookup
    current = getattr(current, bit)
AttributeError: 'URLResolver' object has no attribute 'name'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "D:\Python_venvs\foo\lib\site-packages\django\template\base.py", line 849, in _resolve_lookup
    current = current[int(bit)]
ValueError: invalid literal for int() with base 10: 'name'

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "D:\Python_venvs\foo\lib\site-packages\django\template\base.py", line 856, in _resolve_lookup
    (bit, current))  # missing attribute
django.template.base.VariableDoesNotExist: Failed lookup for key [name] in <URLResolver <URLPattern list> (admin:admin) 'admin/'>

2018-06-11 17:42:19,213 django.request WARNING  Not Found: /foo/

Я искал почти везде, но я не могу найти никого, кто имел подобную проблему.

Техническая настройка:

  • Windows Server 2012
  • IIS 8
  • Джанго 2.0.5
  • Python 3.6.5

Есть идеи?

Изменить: urls.py

from django.contrib import admin
from django.urls import path,include
from polls import views


urlpatterns = [
    path('admin/', admin.site.urls),
    # path('polls/', include('polls.urls')),

]

Я создал приложение опросов в этом проекте django, но прокомментировал его на данный момент, так как оно показывало ту же ошибку для него. Поэтому я решил сначала решить проблему с администратором (которая, я считаю, также исправит проблему приложения опросов)

Моя структура проекта foo:

foo
├── manage.py
├── web.config
├── foo
| ├── settings.py
| └── urls.py
| └── wsgi.py
| └──__init__.py
| └── static
|    ├── admin 
|    |  ├───css
|    |  └── fonts
|    |  └── img
|    |  └── js 
|    └── web.config
├── polls
| ├── admin.py
| └── urls.py
| └── apps.py
| └── models.py
| └── views.py
| └── tests.py
| └── migrations

1 ответ

Решение

Я думаю, что вы не добавили шаблон URL, чтобы направить вас к 127.0.0.1:8000/foo

В urls.py в папке проекта добавьте следующее

url(r'foo/$', view_name, name='foo'),

Это добавит маршрут к /foo/

( (None: None) ''>,)

Другие вопросы по тегам