get() returned more than one Product -- it returned 2!
Request Method: | GET |
---|---|
Request URL: | https://stels.start-dv.ru/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/ |
Django Version: | 3.0.8 |
Exception Type: | MultipleObjectsReturned |
Exception Value: | get() returned more than one Product -- it returned 2! |
Exception Location: | /var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/db/models/query.py in get, line 419 |
Python Executable: | /usr/bin/uwsgi-core |
Python Version: | 3.8.2 |
Python Path: | ['.', '', '/usr/lib/python38.zip', '/usr/lib/python3.8', '/usr/lib/python3.8/lib-dynload', '/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages'] |
Server time: | Пт, 29 Мар 2024 08:06:36 +0300 |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@wraps(get_response)
def inner(request):
try:
response = get_response(request)…
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | MultipleObjectsReturned('get() returned more than one Product -- it returned 2!') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7fa169c7bfd0>> |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/core/handlers/base.py
in _get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)…
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
callback | <function ProductDetailView at 0x7fa16826f8b0> |
callback_args | () |
callback_kwargs | {'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7fa168478070>> |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
resolver | <URLResolver 'system.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=apps.catalog.views.ProductDetailView, args=(), kwargs={'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'}, url_name=product, app_names=[], namespaces=[], route=product/<slug>/) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7fa169c7bfd0> |
wrapped_callback | <function ProductDetailView at 0x7fa16826f8b0> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/core/handlers/base.py
in _get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
callback | <function ProductDetailView at 0x7fa16826f8b0> |
callback_args | () |
callback_kwargs | {'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7fa168478070>> |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
resolver | <URLResolver 'system.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=apps.catalog.views.ProductDetailView, args=(), kwargs={'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'}, url_name=product, app_names=[], namespaces=[], route=product/<slug>/) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7fa169c7bfd0> |
wrapped_callback | <function ProductDetailView at 0x7fa16826f8b0> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/views/generic/base.py
in view
self.head = self.get
self.setup(request, *args, **kwargs)
if not hasattr(self, 'request'):
raise AttributeError(
"%s instance has no 'request' attribute. Did you override "
"setup() and forget to call super()?" % cls.__name__
)
return self.dispatch(request, *args, **kwargs)…
view.view_class = cls
view.view_initkwargs = initkwargs
# take name and docstring from class
update_wrapper(view, cls, updated=())
Variable | Value |
---|---|
args | () |
cls | <class 'apps.catalog.views.ProductDetailView'> |
initkwargs | {} |
kwargs | {'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'} |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
self | <apps.catalog.views.ProductDetailView object at 0x7fa167e643d0> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/views/generic/base.py
in dispatch
# Try to dispatch to the right method; if a method doesn't exist,
# defer to the error handler. Also defer to the error handler if the
# request method isn't on the approved list.
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)…
def http_method_not_allowed(self, request, *args, **kwargs):
logger.warning(
'Method Not Allowed (%s): %s', request.method, request.path,
extra={'status_code': 405, 'request': request}
)
Variable | Value |
---|---|
args | () |
handler | <bound method BaseDetailView.get of <apps.catalog.views.ProductDetailView object at 0x7fa167e643d0>> |
kwargs | {'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'} |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
self | <apps.catalog.views.ProductDetailView object at 0x7fa167e643d0> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/views/generic/detail.py
in get
context.update(kwargs)
return super().get_context_data(**context)
class BaseDetailView(SingleObjectMixin, View):
"""A base view for displaying a single object."""
def get(self, request, *args, **kwargs):
self.object = self.get_object()…
context = self.get_context_data(object=self.object)
return self.render_to_response(context)
class SingleObjectTemplateResponseMixin(TemplateResponseMixin):
template_name_field = None
Variable | Value |
---|---|
args | () |
kwargs | {'slug': 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe'} |
request | <WSGIRequest: GET '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/'> |
self | <apps.catalog.views.ProductDetailView object at 0x7fa167e643d0> |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/views/generic/detail.py
in get_object
raise AttributeError(
"Generic detail view %s must be called with either an object "
"pk or a slug in the URLconf." % self.__class__.__name__
)
try:
# Get the single item from the filtered queryset
obj = queryset.get()…
except queryset.model.DoesNotExist:
raise Http404(_("No %(verbose_name)s found matching the query") %
{'verbose_name': queryset.model._meta.verbose_name})
return obj
def get_queryset(self):
Variable | Value |
---|---|
pk | None |
queryset | <ProductQuerySet [<Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное>, <Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное.>]> |
self | <apps.catalog.views.ProductDetailView object at 0x7fa167e643d0> |
slug | 'liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe' |
slug_field | 'slug' |
/var/www/vhosts/start-dv.ru/conf/venv/lib/python3.8/site-packages/django/db/models/query.py
in get
if num == 1:
return clone._result_cache[0]
if not num:
raise self.model.DoesNotExist(
"%s matching query does not exist." %
self.model._meta.object_name
)
raise self.model.MultipleObjectsReturned(…
'get() returned more than one %s -- it returned %s!' % (
self.model._meta.object_name,
num if not limit or num < limit else 'more than %s' % (limit - 1),
)
)
Variable | Value |
---|---|
args | () |
clone | <ProductQuerySet [<Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное>, <Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное.>]> |
kwargs | {} |
limit | 21 |
num | 2 |
self | <ProductQuerySet [<Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное>, <Product: liqui moly синтетическое масло 4-т 5w-30 всесезонное.>]> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
CONTENT_LENGTH | '' |
CONTENT_TYPE | '' |
DOCUMENT_ROOT | '/usr/share/nginx/html' |
HTTPS | 'on' |
HTTP_ACCEPT | '*/*' |
HTTP_HOST | 'stels.start-dv.ru' |
HTTP_USER_AGENT | 'claudebot' |
PATH_INFO | '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/' |
QUERY_STRING | '' |
REMOTE_ADDR | '44.210.120.182' |
REMOTE_PORT | '38254' |
REQUEST_METHOD | 'GET' |
REQUEST_SCHEME | 'https' |
REQUEST_URI | '/product/liqui-moly-sinteticheskoe-maslo-4-t-5w-30-vsesezonnoe/' |
SCRIPT_NAME | '' |
SERVER_NAME | 'start-dv.ru' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.1' |
uwsgi.node | b'drv6' |
uwsgi.version | b'2.0.18-debian' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.file_wrapper | '' |
wsgi.input | <uwsgi._Input object at 0x7fa1671d9510> |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
system.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['*'] |
APPEND_SLASH | False |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'users.Account' |
AUTH_VALID_MODULE | 'django.contrib.auth.password_validation' |
BASE_DIR | '/var/www/vhosts/start-dv.ru/project' |
CACHES | {'default': {'BACKEND': 'django_redis.cache.RedisCache', 'KEY_PREFIX': '********************', 'LOCATION': 'redis://127.0.0.1:6379/', 'OPTIONS': {'CLIENT_CLASS': 'django_redis.client.DefaultClient'}, 'TIMEOUT': 600}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CKEDITOR_CONFIGS | {'default': {'allowedContent': True, 'removePlugins': 'stylesheetparser', 'toolbar_Full': [['Styles', 'Format', 'Bold', 'Italic', 'Underline', 'Strike', 'Subscript', 'Superscript', '-', 'RemoveFormat'], ['Image', 'Flash', 'Table', 'HorizontalRule'], ['TextColor', 'BGColor'], ['Smiley', 'sourcearea', 'SpecialChar'], ['Link', 'Unlink', 'Anchor'], ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', '-', 'Blockquote', 'CreateDiv', '-', 'JustifyLeft', 'JustifyCenter', 'JustifyRight', 'JustifyBlock', '-', 'BidiLtr', 'BidiRtl', 'Language'], ['Source', '-', 'Save', 'NewPage', 'Preview', 'Print', '-', 'Templates'], ['Cut', 'Copy', 'Paste', 'PasteText', 'PasteFromWord', '-', 'Undo', 'Redo'], ['Find', 'Replace', '-', 'SelectAll', '-', 'Scayt'], ['Maximize', 'ShowBlocks']]}} |
CKEDITOR_UPLOAD_PATH | 'uploads/' |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
CUSTOM_APPS | ['apps.analytics', 'apps.apiship', 'apps.bonus', 'apps.cart', 'apps.catalog', 'apps.commons', 'apps.compare', 'apps.configuration', 'apps.domains', 'apps.exchange1c', 'apps.feedback', 'apps.index_page', 'apps.komtet', 'apps.nav', 'apps.pages', 'apps.product_options', 'apps.promocode', 'apps.sber_acquiring', 'apps.seo', 'apps.shop', 'apps.stores', 'apps.template_editor', 'apps.users', 'apps.vk_com', 'apps.wishlist', 'apps.webp_converter'] |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 600, 'ENGINE': 'django.db.backends.postgresql', 'HOST': '', 'NAME': 'start-dv-ru', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'start-dv-ru'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 10000 |
DATETIME_FORMAT | 'd.m.Y H:i:s' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%Y-%m-%d', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%Y', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M', '%m/%d/%y'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_DOMAIN | 'start-dv.ru' |
DEFAULT_DOMAIN_DISPLAY | 'Интернет-магазин' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'ADJUSTME@srvunknown.ps' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'm1.system.place-start.ru' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | None |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_CHARSET | 'utf-8' |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 200000000 |
FILE_UPLOAD_PERMISSIONS | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['apps.jet_fix', 'jet.dashboard', 'jet', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.sitemaps', 'django_extensions', 'debug_toolbar', 'django_redis', 'sorl.thumbnail', 'ckeditor', 'ckeditor_uploader', 'mptt', 'adminsortable2', 'simple_history', 'colorfield', 'solo', 'captcha', 'apps.analytics', 'apps.apiship', 'apps.bonus', 'apps.cart', 'apps.catalog', 'apps.commons', 'apps.compare', 'apps.configuration', 'apps.domains', 'apps.exchange1c', 'apps.feedback', 'apps.index_page', 'apps.komtet', 'apps.nav', 'apps.pages', 'apps.product_options', 'apps.promocode', 'apps.sber_acquiring', 'apps.seo', 'apps.shop', 'apps.stores', 'apps.template_editor', 'apps.users', 'apps.vk_com', 'apps.wishlist', 'apps.webp_converter'] |
INTERNAL_IPS | [] |
JET_INDEX_DASHBOARD | 'dashboard.CustomIndexDashboard' |
JET_SIDE_MENU_ITEMS | [{'app_label': 'domains', 'items': [{'name': 'domains.domain'}], 'permissions': ['domains.change_domain']}, {'items': [{'name': 'configuration.settings'}, {'name': 'index_page.indexsettings'}, {'name': 'catalog.catalogsettings'}, {'name': 'shop.shopsettings'}], 'label': 'Настройки'}, {'app_label': 'nav', 'items': [{'name': 'headermenuitem'}, {'name': 'footermenuitem'}, {'name': 'sidebarmenuitem'}], 'permissions': ['nav.change_headermenuitem']}, {'app_label': 'pages', 'items': [{'name': 'page'}, {'name': 'heading'}, {'name': 'post'}, {'name': 'offer'}], 'permissions': ['pages.change_page']}, {'app_label': 'catalog', 'items': [{'name': 'category'}, {'name': 'product'}, {'name': 'brand'}, {'name': 'productattribute'}, {'name': 'attributevalue'}], 'permissions': ['catalog.change_product']}, {'app_label': 'stores', 'items': [{'name': 'store'}, {'name': 'storeproductquantity'}]}, {'app_label': 'shop', 'items': [{'name': 'order'}, {'name': 'shopsettings'}, {'name': 'payment'}, {'name': 'shipping'}], 'permissions': ['shop.change_order']}, {'app_label': 'exchange1c', 'items': [{'name': 'settings'}], 'permissions': ['exchange1c.change_settings']}, {'app_label': 'sber_acquiring', 'items': [{'name': 'sbersettings'}], 'permissions': ['sbersettings.change_sbersettings']}, {'app_label': 'komtet', 'items': [{'name': 'komtetsettings'}], 'permissions': ['komtet.change_komtetsettings']}, {'app_label': 'bonus', 'items': [{'name': 'bonussettings'}, {'name': 'bonusaccount'}, {'name': 'action'}], 'permissions': ['bonus.change_bonussettings']}, {'app_label': 'promocode', 'items': [{'name': 'promocode'}]}, {'app_label': 'apiship', 'items': [{'name': 'ordershipping'}], 'permissions': ['apiship.change_ordershipping']}, {'app_label': 'feedback', 'items': [{'name': 'recipient'}, {'name': 'questionsubmit'}]}, {'app_label': 'vk_com', 'items': [{'name': 'vksettings'}, {'name': 'vkproduct'}]}, {'app_label': 'users', 'items': [{'name': 'users.account'}, {'name': 'auth.group'}]}] |
JET_THEMES | [{'color': '#47bac1', 'theme': 'default', 'title': 'Default'}, {'color': '#44b78b', 'theme': 'green', 'title': 'Green'}, {'color': '#2faa60', 'theme': 'light-green', 'title': 'Light Green'}, {'color': '#a464c4', 'theme': 'light-violet', 'title': 'Light Violet'}, {'color': '#5EADDE', 'theme': 'light-blue', 'title': 'Light Blue'}, {'color': '#222', 'theme': 'light-gray', 'title': 'Light Gray'}] |
LANGUAGES | (('ru', 'Русский'), ('en', 'Английский')) |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
LANGUAGE_CODE | 'ru' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/var/www/vhosts/start-dv.ru/project/../media' |
MEDIA_ROOT_WEBP | '/var/www/vhosts/start-dv.ru/project/../' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'debug_toolbar.middleware.DebugToolbarMiddleware', 'django.middleware.locale.LocaleMiddleware', 'simple_history.middleware.HistoryRequestMiddleware', 'apps.domains.middleware.CurrentDomainMiddleware', 'apps.configuration.middleware.AppsRequestMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'system.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | True |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | None |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 1209600 |
SESSION_COOKIE_DOMAIN | '.start-dv.ru' |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SAMESITE | 'Lax' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.cache' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'system.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | ['captcha.recaptcha_test_key_error'] |
SOLO_CACHE | 'default' |
SOLO_CACHE_TIMEOUT | 300 |
STATICFILES_DIRS | [] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/var/www/vhosts/start-dv.ru/project/static' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/var/www/vhosts/start-dv.ru/project/templates'], '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', 'apps.webp_converter.context_processors.webp_support', 'apps.domains.context_processors.context_domains', 'apps.cart.context_processors.cart', 'apps.configuration.context_processors.context_settings', 'apps.nav.context_processors.context_nav', 'apps.catalog.context_processors.context_catalog', 'apps.wishlist.context_processors.wishlist', 'apps.compare.context_processors.compare']}}] |
TEMPLATE_DIR | '/var/www/vhosts/start-dv.ru/project/templates' |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
THUMBNAIL_KEY_PREFIX | '********************' |
THUMBNAIL_KVSTORE | 'sorl.thumbnail.kvstores.redis_kvstore.KVStore' |
THUMBNAIL_PRESERVE_FORMAT | True |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'Europe/Moscow' |
USE_I18N | True |
USE_L10N | False |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'system.wsgi.application' |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
YEAR_MONTH_FORMAT | 'F Y' |
You're seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.