Я пытаюсь разместить приложение 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 в следующем порядке:
admin /
Текущий путь 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
- Django 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