Django: ошибка "Без модуля с именем context_processors" после перезагрузки
У меня есть сайт Django, который работает на моем ПК, и вскоре он работал на моем сервере после его загрузки. Я заметил, что у моего сервера был Django 1.6, и я обновился до 1.8.
После перезагрузки ни одна из страниц на моем сайте не загружается, и я получаю сообщение об ошибке:
ImportError Нет модуля с именем context_processors
Я прочитал документы о Django и allauth. Джанго упоминает, что в 1.8 переходы context_processors и allauth говорят, что в теге TEMPLATE_CONTEXT_PROCESSORS
от settings.py
больше не нужны специальные теги allauth.
Django: https://docs.djangoproject.com/en/1.8/ref/settings/
Allauth: https://django-allauth.readthedocs.org/en/latest/installation.html
Кто-нибудь еще сталкивается с этим? Я на правильном пути? Нужно ли что-то менять в настройках? Я не могу сказать, если это проблема Django или allauth, поэтому не знаю, с чего начать.
Любая помощь приветствуется!
Traceback:
Django Version: 1.8.4
Python Version: 2.7.6
Installed Applications:
('django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'plant',
'journal',
'userimg',
'django.contrib.sites',
'allauth',
'allauth.account')
Installed Middleware:
('django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware')
Traceback:
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/core/handlers/base.py" in get_response
132. response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/home/django/django_project/plant/views.py" in plant_main
24. return render(request, 'plant/plant_main.html', context)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/shortcuts.py" in render
67. template_name, context, request=request, using=using)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/loader.py" in render_to_string
99. return template.render(context, request)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/backends/django.py" in render
74. return self.template.render(context)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/base.py" in render
208. with context.bind_template(self):
File "/usr/lib/python2.7/contextlib.py" in __enter__
17. return self.gen.next()
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/context.py" in bind_template
237. processors = (template.engine.template_context_processors +
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/utils/functional.py" in __get__
60. res = instance.__dict__[self.name] = self.func(instance)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/engine.py" in template_context_processors
90. return tuple(import_string(path) for path in context_processors)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/template/engine.py" in <genexpr>
90. return tuple(import_string(path) for path in context_processors)
File "/usr/local/lib/python2.7/dist-packages/Django-1.8.4-py2.7.egg/django/utils/module_loading.py" in import_string
26. module = import_module(module_path)
File "/usr/lib/python2.7/importlib/__init__.py" in import_module
37. __import__(name)
Exception Type: ImportError at /plant/
Exception Value: No module named context_processors
Ответы
Ответ 1
Проблема заключалась в том, что у меня не было настройки TEMPLATES в settings.py, как требуется после перехода на Django 1.8. Я не совсем понимаю, почему он работал на моем компьютере с помощью сервера Django.
Из документов allauth я вложил это в свой файл настроек:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
# Already defined Django-related contexts here
# `allauth` needs this from django
'django.template.context_processors.request',
],
},
},
]
И скопировал содержимое моего старого параметра TEMPLATE_DIRS
в определение DIRS для TEMPLATES. Окончательный результат выглядит следующим образом:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
# Already defined Django-related contexts here
# `allauth` needs this from django
'django.template.context_processors.request',
],
},
},
]
В соответствии с документацией для недавнего обновления allauth, context_processors
теперь необходимо указать в настройках TEMPLATES, а не TEMPLATE_CONTEXT_PROCESSORS
.
Благодаря Joey Wilhelm для указания меня в правильном направлении.
Ответ 2
Я столкнулся с той же проблемой, но я обновляюсь с 1.9.1 до 1.10. Я обнаружил там небольшую разницу в настройках.
Это код из 1.9.1
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.core.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
Это код для 1.10
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, 'templates')],
'APP_DIRS': True,
'OPTIONS': {
'context_processors': [
'django.template.context_processors.debug',
'django.template.context_processors.request',
'django.contrib.auth.context_processors.auth',
'django.contrib.messages.context_processors.messages',
],
},
},
]
Строка django.core.context_processors.request
недействительна в 1.10. Удалите его, и код работает хорошо.
Ответ 3
Только совет: когда трассировка не предоставляет вам информацию, необходимую для идентификации точной строки кода; Может быть полезно включить режим DEBUG
и открыть страницу в браузере. Там этот замечательный маленький local_vars
элемент, где вы можете увидеть локальное состояние переменной, когда происходит трассировка. Это может быть очень удобно!
(В моем случае это было связано с изменениями внутри allauth)