pycharm创建django项目的setting配置

pycharm创建django项目的setting配置

"""
Django settings for Django 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__)))


# 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 = '@z$ck)-0nb&z6tnb+bnkk)vyz7ttdfr*r56#3$++-t@)b!==a-'

# SECURITY WARNING: don't run with debug turned on in production!
# DEBUG是指调试模式,项目上线前必须改为False, 改为False找不到静态目录static
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',
    # 把自己的应用进行安装,往下添加
    'app',  # 一些常用的路由,视图函数的设置,模板,模型,过滤器等
    'app01',  # 登录注册功能,用cookie或者session保存用户信息,创建表单验证注册格式
    'app02',  # 后台管理功能,主要配置在app02:admin下, 使用前数据库配置换成admin
    'rest_framework',  # DRF框架,需要先 pip install djangorestframework
    'app03',  # DRF有关,序列化器,认证,权限控制,节流
    'django_filters',  # 第三方过滤器,需要先 pip install django-filter
    'corsheaders',  # 处理跨域问题的第三方插件,要先pip install django-cors-headers
]

# 中间件: 先于框架获得用户的请求,执行顺序按下面的配置顺序从上到下
MIDDLEWARE = [
    # 处理跨域,安装完插件添加INSTALLED_APPS应用,然后配置在这里的第一条
    'corsheaders.middleware.CorsMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    # csrf验证防止外界跨站攻击,注释掉会全站禁止检测
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

# 根路由文件
ROOT_URLCONF = 'Django.urls'

# 模板配置
TEMPLATES = [
    {
        # 配置模板引擎,可以换为jinja2,先pip install jinja2
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        # 指定模板目录的路径,换成jinja2后要换与之对应的模板目录路径
        '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 = 'Django.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.2/ref/settings/#databases
# 数据库配置,先pip install mysqlclient
# 如果表已经存在,输入python manage.py inspectdb > app/models.py
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',  # 默认是sqllite3,改为mysql
        # 创建空库后执行 python manage.py makemigrations
        # 生成迁移文件app/migrations/0001_initial.py
        # 会创建迁移文件里指定的表名name:
        # 执行python manage.py migrate完成数据迁移
        # 一般是建库建表后反向生成models模型文件:python manage.py inspectdb > app/models.py
        'NAME': 'pydata',
        'HOST': '127.0.0.1',
        'USER': 'root',
        'PASSWORD': '*********',
        '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'  # 改为中文zh-hans

# 时区
TIME_ZONE = 'Asia/Shanghai'  # 改为上海Asia/Shanghai

USE_I18N = True

USE_L10N = True

# 使用国际标准时间
# 默认是Ture 改为 False,可以使数据库里存储时间和当地一致
USE_TZ = False


# 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')
]

# 设置DRF
REST_FRAMEWORK = {
    # 设置缺省的过滤器支持,先pip install django-filter,然后在INSTALLED_APPS添加应用,最后来指定
    'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',),
    # 使用第三方库自动生成接口文档,需要先安装pip install coreapi
    # 安装完成后在项目根目录的urls.py内配置
    'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema',
    # 'DEFAULT_PARSER_CLASSES': (
    #     # 设置JOSN默认解析器,可以追加,不指定时由DRF判断request数据类型来使用对应的解析器
    #     'rest_framework.parsers.JSONParser',
    # ),
    # # 定义全局验证
    # 'DEFAULT_AUTHENTICATION_CLASSES': (
    #     # 应用名.模块名.认证类名
    #     'App.MyAuthentications.MyAuthentaion',
    # ),
    # # 指定自定义节流器,进行全局节流,访问频率在自定义节流器已经限制,不用添加zdy: '3/m'
    # 'DEFAULT_THROTTLE_CLASSES': ['app03.MyThrottle.MyThrottle'],
    # # 指定DRF自己定义的节流器
    # 'DEFAULT_THROTTLE_CLASSES': ['rest_framework.throttling.AnonRateThrottle'],
    # 'DEFAULT_THROTTLE_RATES': {
    #    'anon': '2/day',  # 匿名用户
    # },
}

# 处理跨域
CORS_ALLOW_CREDENTIALS = True
CORS_ORIGIN_ALLOW_ALL = True
CORS_ORIGIN_WHITELIST = (
    'http://127.0.0.*',
    "http://localhost"
)

CORS_ALLOW_METHODS = (
    'DELETE',
    'GET',
    'OPTIONS',
    'PATCH',
    'POST',
    'PUT',
)

CORS_ALLOW_HEADERS = (
    'XMLHttpRequest',
    'X_FILENAME',
    'accept-encoding',
    'authorization',
    'content-type',
    'dnt',
    'origin',
    'user-agent',
    'x-csrftoken',
    'x-requested-with',
)

# 使用本地配置文件localsettings:
try:
    from .localsettings import *
except ImportError:
    pass

# 开始运行
# python manage.py runserver
# 新建模块
# python manage.py startapp app01

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2020 CSDN 皮肤主题: 1024 设计师:白松林 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值