关于django框架的一些配置(settings.py)

  • M 代表模型(Model): 负责业务对象和数据库的关系映射(ORM)。
  • T 代表模板 (Template):负责如何把页面展示给用户(html)。
  • V 代表视图(View):   负责业务逻辑,并在适当时候调用Model和Template。

  除了以上三层之外,还需要一个URL分发器,它的作用是将一个个URL的页面请求分发给不同的View处理,View再调用相应的Model和Template,MTV的响应模式如下所示:

  

 

  ①url配置

    # 是否开启URL访问地址后面不为‘/’跳转至带有‘/’的路径的配置项

      访问 http://www.example.com/blog 时,默认将网址自动转换为 http://www.example/com/blog/ 。

      APPEND_SLASH=True(settings.py中默认没有这个,按需求配置,没有配置的时候默认是True)

      如果在settings.py中设置了 APPEND_SLASH=False,此时再请求 http://www.example.com/blog 时就会提示找不到页面。

  ②view配置      # Application definition


    INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles', # 上面的这些配置是django框架自带的
    'app01.apps.App01Config',  
    'app02.apps.App02Config',  # 两个app应用,项目中添加一个应用都要在这里改成文件夹的名字,直接写“app01”也可以。
       # 可以看到“app01”文件夹下apps.py 就知道为什么这个文件配置是这样了。
    ]

    MIDDLEWARE = [
     'django.middleware.security.SecurityMiddleware',
     'django.contrib.sessions.middleware.SessionMiddleware',
     'django.middleware.common.CommonMiddleware',
     'django.middleware.csrf.CsrfViewMiddleware', # 这个是POST请求认证安全机制,如果django框架没有拿到html页面中CSRF值是提交不了的,一种伪保护
     'django.contrib.auth.middleware.AuthenticationMiddleware',
     'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]
  ③templates模板
    TEMPLATES = [
      {
   'BACKEND': 'django.template.backends.django.DjangoTemplates',
  'DIRS': [os.path.join(BASE_DIR, 'templates')], # 配置放html文件的路径,url配置中的路径都会自动找到改路径下的html文件
  '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',
    ],
     },
     },
      ]
    # 静态文件配置 比如css,js,图片视频等。
      STATIC_URL = '/static/' #别名,在urls.py中加多一个name=‘别名’参数,便于维护更新迭代
      STATICFILES_DIRS = [
           os.path.join(BASE_DIR,'jingtaiwenjian'), #注意别忘了写逗号,第二个参数就是项目中你存放静态文件的文件夹名称
      ]
  ④models模型
    LANGUAGE_CODE = 'en-us' 

    TIME_ZONE = 'UTC' # 设置时区地区 如'Asia/Shanghai'
    USE_I18N = True

    USE_L10N = True
    APPEND_SLASH = FALSE # 不会再url后自动加“/”

    USE_TZ = True # 在操作数据库的时候,涉及时间日期的要注意,这个True表示让数据库考虑时区的问题,False则不考虑时区问题,会将本地时间写入

    DATABASES = {
      'default': {
        'ENGINE': 'django.db.backends.mysql',    # 要连接其他数据库 改动‘mysql’即可
        'NAME':'bms',      # 要连接的数据库,连接前需要创建好
        'USER':'root',       # 连接数据库的用户名
        'PASSWORD':'',       # 连接数据库的密码
        'HOST':'127.0.0.1',         # 连接主机,默认本机
        'PORT':3306     # 端口 默认3306

        'OPTIONS': {
            "init_command": "SET default_storage_engine='INNODB'",       

            # 'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",

        }         

        "ATOMIC_REQUESTS": True, #全局开启事务,绑定的是http请求响应整个过程,不建议配置,不是所有sql语句都需要用到事务的

      'other':{
        'ENGINE': 'django.db.backends.mysql', 
            ......
      } #还可以配置其他数据库

      }

    DATABASES['default']['OPTIONS']['init_command'] = "SET sql_mode='STRICT_TRANS_TABLES'" # 设置成严格模式,在项目中若出现关于Mode的警告,可以在django项目这里设置,或者去数据库设置成严格模式。
    
    #下面的代码放进settings.py中 可以看到原生sql语句执行

    LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
    'console':{
    'level':'DEBUG',
    'class':'logging.StreamHandler',
    },
    },
    'loggers': {
    'django.db.backends': {
    'handlers': ['console'],
    'propagate': True,
    'level':'DEBUG',
    },
    }
    }

    

 

posted @ 2020-06-17 23:13  小丞cc  阅读(257)  评论(0编辑  收藏  举报