我遇到了一个非常烦人的错误,每当我将有效负载添加到任何类型的请求中时,我会遇到500个错误,说“服务器陷入困境”。方法无关紧要:它可以是一个获取,发布,放置,补丁或删除,并且仍然会遇到错误...

问题描述 投票:0回答:0

在服务器上有一些细节,可以提供洞察力: For instance, a GET request with some payload will give this error

The same request, but without a request body 该应用程序在炮棒容器内运行

clentient请求转到反向代理,然后将其重定向到App

应用程序处理传入的请求,并正在为他们倾听

我正在使用的设置也是我正在使用的设置。我现在已经debug = true,以尝试达到问题的根源...Diagram of how the external server works """ Django settings for server project. Generated by 'django-admin startproject' using Django 5.1.4. For more information on this file, see https://docs.djangoproject.com/en/5.1/topics/settings/ For the full list of settings and their values, see https://docs.djangoproject.com/en/5.1/ref/settings/ """ from pathlib import Path from datetime import timedelta from cryptography.fernet import Fernet import sys import environ import os env = environ.Env() environ.Env.read_env() USE_X_FORWARDED_HOST = True # Build paths inside the project like this: BASE_DIR / 'subdir'. BASE_DIR = Path(__file__).resolve().parent.parent # Quick-start development settings - unsuitable for production # See https://docs.djangoproject.com/en/5.1/howto/deployment/checklist/ # SECURITY WARNING: keep the secret key used in production secret! SECRET_KEY = 'django-insecure-(ltwgqma)#6=y3!dcw4b&8sog&%y@i51d1ye*(w_fk$9p0tvip' ENCRYPTED_FIELDS_KEY = env('ENCRYPTED_FIELDS_KEY') # SECURITY WARNING: don't run with debug turned on in production! DEBUG = True ALLOWED_HOSTS = ['*'] # Application definition INSTALLED_APPS = [ 'daphne', 'django_eventstream', 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django_extensions', 'django_apscheduler', 'rest_framework', 'rest_framework_simplejwt.token_blacklist', 'corsheaders', 'apps.api' ] MIDDLEWARE = [ 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', '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', ] ROOT_URLCONF = 'server.urls' TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], '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', ], }, }, ] # WSGI_APPLICATION = 'server.wsgi.application' ASGI_APPLICATION = "server.asgi.application" # Database # https://docs.djangoproject.com/en/5.1/ref/settings/#databases DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': 'server.com', 'NAME': env('DB_NAME'), 'USER': env('DB_USERNAME'), 'PASSWORD': env('DB_PASSWORD') } } # Password validation # https://docs.djangoproject.com/en/5.1/ref/settings/#auth-password-validators AUTH_PASSWORD_VALIDATORS = [ { 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', }, { 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', }, { 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', }, { 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', }, ] LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_TZ = True FIXTURE_DIRS = [ 'fixtures' ] STATIC_URL = 'static/' MEDIA_ROOT = os.path.join(os.path.dirname(BASE_DIR), "server/media") DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' CORS_ALLOW_ALL_ORIGINS = True AUTH_USER_MODEL = "users.User" REST_FRAMEWORK = { 'DEFAULT_PERMISSION_CLASSES': [ 'rest_framework.permissions.AllowAny', ], 'DEFAULT_AUTHENTICATION_CLASSES': [ 'rest_framework_simplejwt.authentication.JWTAuthentication', ], 'DEFAULT_RENDERER_CLASSES': [ 'rest_framework.renderers.JSONRenderer', ], 'DEFAULT_PARSER_CLASSES': [ 'rest_framework.parsers.JSONParser', ] } SIMPLE_JWT = { 'ACCESS_TOKEN_LIFETIME': timedelta(minutes=10), 'REFRESH_TOKEN_LIFETIME': timedelta(days=1), 'ROTATE_REFRESH_TOKENS': True, 'BLACKLIST_AFTER_ROTATION': False, 'USER_ID_FIELD': 'user_id' } LOGGING = { "version": 1, "disable_existing_loggers": False, "handlers": { "console": { "class": "logging.StreamHandler", }, }, "root": { "handlers": ["console"], "level": "WARNING", }, } if 'test' in sys.argv: DATABASES['default'] = { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': 'test' }

    我可以访问的日志,但是除了指示错误外,没有其他地方。
  • 感谢您可以帮助我达到最底层的任何人!
  • 错误似乎正在发生,因为视图没有在访问其属性之前检查用户是否已进行身份验证。 Django使用Anonymoususer来处理未经验证的用户会话,并且该模型没有user_id字段,这会导致500错误。
  • 检查您的视图以查看是否确保用户在尝试访问user_id之前已进行身份验证。这样的事情可能会有所帮助:

api/users 404: Bad request

wo,为了帮助您更好,您能否分享您的完整视图的代码?具体来说,如何获取用户并访问其属性。
	

python django apache django-rest-framework gunicorn
最新问题
© www.soinside.com 2019 - 2025. All rights reserved.