Azure Django 应用程序有 SECRET_KEY 异常

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

我使用 GitHub 在 azure 上部署了 django Web 应用程序,但我收到的错误是:

django.core.exceptions.ImproperlyConfigured:SECRET_KEY 设置不能为空。

我的settings.py文件是

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

SECRET_KEY = os.getenv('SECRET_KEY')

DEBUG = False

TEMPLATE_DEBUG = DEBUG

ALLOWED_HOSTS = os.getenv('ALLOWED_HOSTS')


STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static/'),
    "C:/Users/ande/Documents/FC_Database/FC_Database/frontend/templates/frontend/index.html"
]


# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'SLAR',
    'import_export',
    'rest_framework',
    'frontend'
]

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',
]

ROOT_URLCONF = 'FC_Database.urls'

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',
            ],
        },
    },
]

WSGI_APPLICATION = 'FC_Database.wsgi.application'

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': os.getenv('NAME'),
        'USER': os.getenv('USER'),
        'PASSWORD': os.getenv('PASSWORD'),
        'PORT': 3306,
        'HOST': os.getenv('HOST')
    }
}

# Password validation
# https://docs.djangoproject.com/en/2.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',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/2.1/topics/i18n/

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/

STATIC_URL = '/static/'

MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
MEDIA_URL = '/media/'

出于安全原因,我在 Azure 的应用程序设置中添加了密钥和其他数据库设置,但它仍然不起作用。 enter image description here 有谁知道如何解决这个问题?

django azure settings secret-key
2个回答
0
投票

Python 允许您使用 os.environ 字典检索环境变量的内容,其中键是您尝试获取其内容的变量的名称。

这是可用于从 Azure WebApp 检索环境变量的部分代码

import os
...
SECRET_KEY = os.environ['SECRET_KEY']
...

https://docs.djangoproject.com/en/3.1/howto/deployment/checklist/


0
投票

我知道这是一个老问题,但作为“collectstatic”操作的一部分,我一整天都在努力解决这个问题。我突然意识到这个(manage.py Collectstatic)是在构建中运行的(在我的例子中是在 GitHub Actions 中),而不是在 Azure 上运行,因此当然无法访问 Azure 环境变量。

Collectstatic 也不需要它们,所以我更新了我的设置模块以忽略环境中未设置的任何内容,并且它现在可以很好地完成构建过程。

© www.soinside.com 2019 - 2024. All rights reserved.