企业🤖AI Agent构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
[TOC] ## BASE_DIR 项目路径 ```python BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) ``` BASE_DIR为当前项目的绝对路径 ## DEBUG 模式 ``` DEBUG = True ``` 是否开启debug模式 ## ROOT_URLCONF 项目的url配置文件目录,如下 ``` ROOT_URLCONF = 'django_project.urls' ``` ## DATABASES 数据库设置 数据库的配置项,默认为Python自带的sqllite3 ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } } ``` 可以自己配置为mysql等,例 ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'django', 'USER':'root', 'PASSWORD':'', 'HOST':'localhost', 'PORT':'3306' } } ``` ## 国际化 ``` LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai' ``` 前边已经提到,不在多叙述 ## 静态文件 项目中的CSS、图片、js都是静态文件。一般会将静态文件放到一个单独的目录中,以方便管理。在html页面中调用时,也需要指定静态文件的路径,Django中提供了一种解析的方式配置静态文件路径。静态文件可以放在项目根目录下,也可以放在应用的目录下,由于有些静态文件在项目中是通用的,所以一般放在项目的根目录下,方便管理。 - **STATIC_URL** 访问静态文件的URL前缀 - **STATICFILES_DIRS** 存放查找静态文件的目录 ### 访问静态文件示例 `settings.py` 文件下添加代码 ```python STATIC_URL = '/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, "static"), ] ``` 制定访问url为 `/static/` ,存放目录为项目根目录下的 `static` 文件夹。 在项目根目录下新建文件夹 `static` 此时 `static` 目录下的任何静态文件就可以通过下边方式来访问 ``` 网址+/static/+文件在static目录下的存放路径 ``` - django仅在 `DEBUG=True` 的时候可以对外部提供静态文件访问的功能。 ## ALLOWED_HOSTS ALLOWED_HOSTS是一个字符串列表,代表了这个Django网站可以服务的主机名或域名。这是为了阻止HTTP Host头攻击而采用的一种安全措施。 这个列表中的值,可以是全名(比如: 'www.baidu.com'), 在这种情况下,它们会直接与所要求的Host头进行匹配(大小写不区分,不包括端口号)。 如果一个值以点号开始,则可当做一个子域名通配符:'.baidu.com'会匹配'baidu.com', 'www.baidu.com', 以及baidu.com的其它任意子域名。如果有'*'这个值,那么它会匹配任何字符串,在这种情况下,你就需要提供你自己的Host头验证机制。 配置格式如下: ``` ALLOWED_HOSTS = [ '.baid.com', '.baidu.com.', ``` - DEBUG设置为False的时候必须配置这个配置.否则会抛出异常。 ## TEMPLATES 模板设置 EMPLATES项指定了django如何载入和渲染模板 APP_DIRS项被设置为了True,代表django会在每个app目录内寻找templates子目录,所以不需要我们进行DIRS的设置。而如果templates要放在其他文件夹下,则需要设置DIRS项 ```python 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', ], }, }, ] ``` ## INSTALLED_APPS 注册APP NSTALLED_APPS项保存了工程中已经注册安装的子应用 注册安装一个子应用的方法,即是将子应用的配置信息文件apps.py中的Config类添加到INSTALLED_APPS列表中。 例如,将刚创建的users子应用添加到工程中,可在INSTALLED_APPS列表中添加 `demo.apps.UsersConfig` ```python INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'demo.apps.DemoConfig' ] ``` ## MIDDLEWARE 中间件 web应用中需要加载的一些中间件列表.是一个一元数组.里面是django自带的或者定制的中间件包路径,如下 ```python 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', ] ```