【发布时间】:2019-02-05 20:24:31
【问题描述】:
我正在将 django 应用程序从 1.x 移植到 2.1,但遇到了“TypeError:object() 不接受任何参数”的错误消息。我试图解决这个问题很长一段时间,但即使经过几天的调试和在线搜索,我什至没有得到任何线索
已安装的应用:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.sites',
'allauth',
'allauth.account',
'allauth.socialaccount',
'allauth.socialaccount.providers.github',
'timezone_field',
'axes',
'humans',
'boxes',
'pages',
]
中间件设置:
MIDDLEWARE = [
'whitenoise.middleware.WhiteNoiseMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.locale.LocaleMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'django.middleware.security.SecurityMiddleware',
]
缩进没有问题,
芹菜版本:4.2.1
乌鸦版本:6.9.0
django 版本:2.1
这是我的 wsgi.py
import os
from raven.contrib.django.raven_compat.middleware.wsgi import Sentry
from django.core.wsgi import get_wsgi_application
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
application=Sentry(get_wsgi_application())
这是错误日志的摘录
File "/usr/lib/python3.5/importlib/__init__.py", line 126, in import_module
return _bootstrap._gcd_import(name[level:], package, level)
File "<frozen importlib._bootstrap>", line 986, in _gcd_import
File "<frozen importlib._bootstrap>", line 969, in _find_and_load
File "<frozen importlib._bootstrap>", line 958, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 673, in _load_unlocked
File "<frozen importlib._bootstrap_external>", line 665, in exec_module
File "<frozen importlib._bootstrap>", line 222, in _call_with_frames_removed
File "/app/wsgi.py", line 16, in <module>
application=Sentry(get_wsgi_application())
File "/usr/local/lib/python3.5/dist-packages/django/core/wsgi.py", line 13, in get_wsgi_application
return WSGIHandler()
File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/wsgi.py", line 136, in __init__
self.load_middleware()
File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py", line 36, in load_middleware
mw_instance = middleware(handler)
TypeError: object() takes no parameters
使用 CustomSentry 后出错:
in <module>
application = CustomSentry(get_wsgi_application())
File "/usr/local/lib/python3.5/dist-packages/django/core/wsgi.py", line 13, in get_wsgi_application
return WSGIHandler()
File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/wsgi.py", line 136, in __init__
self.load_middleware()
File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py", line 36, in load_middleware
mw_instance = middleware(handler)
TypeError: object() takes no parameters
我尝试使用 ExceptionMiddleware 捕获异常,现在我收到以下错误:
application = CustomSentry(get_wsgi_application())
File "/usr/local/lib/python3.5/dist-packages/django/utils/deprecation.py", line 85, in __init__
super().__init__()
TypeError: __init__() missing 1 required positional argument: 'application'
任何帮助将不胜感激。
【问题讨论】:
-
可以添加文件
/app/wsgi.py吗? -
请用您的
INSTALLED_APPS更新问题;并且您的MIDDLEWARE列表的顺序不正确。'django.middleware.security.SecurityMiddleware',应该高于'whitenoise.middleware.WhiteNoiseMiddleware', -
我建议在
django/utils/deprecation.py的第36行之前添加一个断点(或打印语句)来检查变量middleware_path。 -
你检查过你的中间件版本吗?看起来白噪声将是罪魁祸首。你
pip install --upgrade它是兼容django 2.1的版本吗? -
如上所述,我会尝试找出导致问题的中间件,或者使用断点,或者在导致问题的行上方添加
print语句。
标签: python django python-3.x django-rest-framework python-3.5