【django】settings.py配置文件内容详细介绍

配置文件如下,下面对配置文件进行一一解释

"""
Django settings for film1_manager project.

Generated by 'django-admin startproject' using Django 2.2.

For more information on this file, see
https://docs.djangoproject.com/en/2.2/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/2.2/ref/settings/
"""

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__)))
#BASE_DIR=film_manager

# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.2/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '^-fz_k8_eam%axnvh3@tqd7wjbzfx31*ac3e40ue^)jyaopb2n'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = []


# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'film'
]

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 = 'film1_manager.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 = 'film1_manager.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases

# DATABASES = {
#     'default': {
#         'ENGINE': 'django.db.backends.sqlite3',
#         'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
#     }
# }

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'filmdatabase',
        'USER': 'zilv',
        'PASSWORD': '123456',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    }
}


# Password validation
# https://docs.djangoproject.com/en/2.2/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.2/topics/i18n/

LANGUAGE_CODE = 'zh-Hans'

TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True

USE_TZ = True


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

STATIC_URL = '/static/'
STATICFILES_DIRS=[
    os.path.join(BASE_DIR,'static')
]

1、BASE_DIR: 当前⼯程的根⽬录,Django会依此来定位⼯程内的相关⽂件,我们也可以使⽤该参数来构造⽂件路径。

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

2. DEBUG:调试模式,创建⼯程后初始值为True,即默认⼯作在调试模式下。
作⽤:

  • 修改代码⽂件,程序⾃动重启
  • Django程序出现异常时,向前端显示详细的错误追踪信息
  • ⽽⾮调试模式下,仅返回Server Error (500)

3. 本地语⾔与时区

Django⽀持本地化处理,即显示语⾔与时区⽀持本地化。
本地化是将显示的语⾔、时间等使⽤本地的习惯,这⾥的本地化就是进⾏中国化,中国⼤陆地区使⽤简体中⽂,时区使⽤亚洲/上海时区,注意这⾥不使⽤北京时区表示。

初始化的⼯程默认语⾔和时区为英语和UTC标准时区

LANGUAGE_CODE = 'en-us' # 语⾔
TIME_ZONE = 'UTC' # 时区# 时区

将语⾔和时区修改为中国⼤陆信息

LANGUAGE_CODE = 'zh-Hans'
TIME_ZONE = 'Asia/Shanghai'

4.静态⽂件:STATIC_URL、STATICFILES_DIRS

项⽬中的css、image、js都是静态⽂件。⼀般会将静态⽂件放到⼀个单独的⽬录中,以⽅便管理。在html⻚⾯中调⽤时,也需要指定静态⽂件的路径,Django中提供了⼀种解析的⽅式配置静态⽂件路径。静态⽂件可以放在项⽬根⽬录下,也可以放在应⽤的⽬录下,由于有些静态⽂件在项⽬中是通⽤的,所以推荐放在项⽬的根⽬录下,⽅便管理。
为了提供静态⽂件,需要配置两个参数:
STATICFILES_DIRS 存放查找静态⽂件的⽬录
STATIC_URL 访问静态⽂件的URL前缀

例如:

STATIC_URL = '/static/'
STATICFILES_DIRS=[
    os.path.join(BASE_DIR,'static')
]

5、ALLOWED_HOSTS = []:允许访问的ip地址加入到列表中,如果在启动服务指定了ip,python manage.py runserver 192.168.17.6,需要将192.168.17.6加入到ALLOWED_HOSTS中

6、INSTALLED_APPS:将创建的子应用添加到INSTALLED_APPS中,可以直接添加子应用名称或者子应用名称.apps.FilmConfig

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'film'
]

7、MIDDLEWARE:项目中用到的一些中间件

8、ROOT_URLCONF = ‘film1_manager.urls’:项目的根路由
9、TEMPLATES:项目中定义的模板文件,需要配置模板路径

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

10、DATABASES:项目中的数据库配置

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'filmdatabase',
        'USER': 'zilv',
        'PASSWORD': '123456',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    }
}

11、AUTH_PASSWORD_VALIDATORS:用户经常选择错误的密码。为了帮助缓解此问题,Django提供了可插入的密码验证。您可以同时配置多个密码验证器。Django中包含一些验证器,但是编写自己的验证器也很简单。

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
### 回答1: Django 的 `settings.py` 文件是项目的配置文件,用于设置项目的各种参数。它包含了数据库连接信息、静态文件路径、应用程序列表等等。开发者可以在这个文件中自定义设置,以适应项目的需求。 ### 回答2: Django 是一个由 Python 语言编写的高级 Web 框架,它的运行离不开一个配置文件 settings.py。下面我将详细介绍 Django settings.py 的相关配置。 settings.pyDjango 项目的配置文件,它包含了 Django 应用程序所有的配置信息,在这个文件中,可以设置用户认证、静态文件路径、数据库配置以及其他应用程序设置。 1. 数据库配置 在 settings.py 文件中可以设置数据库信息,包括数据库类型、用户名、密码、主机等信息。Django 支持多种数据库,包括 MySQL、PostgreSQL、SQLite 等。默认情况下,Django 使用 SQLite3 作为数据库引擎。 2. 静态文件配置 静态文件指 css、js、image 等静态资源,可以通过配置来指定其路径,以便 Django 能够正确地找到它们。例如: ``` STATIC_URL = '/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ] ``` 在这里,`STATIC_URL` 表示静态文件的 URL 前缀,`STATICFILES_DIRS` 表示静态文件的根目录,其中 `BASE_DIR` 是 Django 项目的根目录。 3. 模板配置 Django 使用模板引擎来生成 HTML 页面。可以在 settings.py 文件中设置模板的路径和选项: ``` 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', ], }, }, ] ``` 在这里,`DIRS` 指定了模板文件所在的目录,`APP_DIRS` 表示是否要在应用目录中查找模板文件。 4. 缓存配置 在对性能要求较高的场合,可以启用缓存机制以提高性能。可以在 settings.py 文件中设置缓存相关的选项: ``` CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', } } ``` 在这里,`BACKEND` 表示缓存的后端,可以使用 Memcached、Redis 等缓存后端。`LOCATION` 表示缓存服务器的地址。 5. 其他配置 除了上述配置项外,还有许多其他的配置项,如统一时间格式、国际化设置、日志配置等等。在使用过程中,需要根据具体的需求进行配置。 总之,Django settings.py 是一个非常重要的配置文件,它对 Django 应用程序的运行有很大的影响。在进行 Django 应用程序开发时,需要了解这些配置信息,以便进行正确的设置。 ### 回答3: Djangosettings.py文件是Django Web框架中最重要的配置文件之一。此文件定义许多控制Django项目外观和行为的变量和选项,如数据库设置、本地化、安全性、静态文件路径、应用程序配置等等。因此,正确配置settings.py文件对于Django项目的成功是至关重要的。 以下是一些必要的settings.py配置: 1. DATABASES:这个选项定义了Django项目中要使用的数据库。默认情况下,Django使用SQLite数据库,但你可以使用其他的数据库,如MySQL、PostgreSQL等。 2. TIME_ZONE:这个选项告诉Django项目时区设置。它通常设置为服务器所在的时区。 3. LANGUAGE_CODE:这个选项定义Django项目默认语言设置。 4. STATIC_URL:在Django项目中,静态文件通常存放在一个被称为“static”的文件夹中。这个选项定义了静态文件URL的路径。 5. MIDDLEWARE_CLASSES:这个选项定义了要在Django项目中使用的中间件。 6. INSTALLED_APPS:这个选项定义了在Django项目中要使用的应用程序列表。Django项目中的应用程序是可重用的模块,它们可以添加到Django项目中,并通过视图模板和其他应用程序类使用。 7. SECRET_KEY:这个选项定义Django项目的密钥。它在项目中用于安全目的。 8. DEBUG:这个选项决定了在Django项目中是否开启Debug模式。在开发过程中,通常应该将Debug模式设置为True,以便发现错误。 这些选项只是Django settings.py文件中的一些必要配置。为了使Django项目成功,开发人员还应该熟悉其他选项和变量,并理解它们如何影响项目的行为。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码敲到头发茂密

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值