天天看点

Django搭建个人博客Blog-Day02

配置文件的介绍:dev.py(原来的setting.py文件)

# django的配置文件中的配置项是什么意思?

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__)))

# 用一个变量来保存一个路径 __file__ :当前这份文件的路径

# 在开发中,路径不要写死,不建议使用绝对路径,避免因为路径变动了造成的bug

# SECURITY WARNING: keep the secret key used in production secret!

SECRET_KEY = 'mu4#59%=%f*e8x6d9+p26f#6ch&5)&+)mte7+wq)717uxu56ap'

# 随机字符串,django 运行必须需要这个,session、加密等情况会使用

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

DEBUG = True # 调试模式

# 设置为Ture 则表示开启调试模式 就会将遇到的错误以及错误信息展示出来

# 在开发的时候,应该开启 方便我们进行排错

# 设置为False 则表示关闭调试模式 不会展示错误信息

# 在生产环境下,不能开启调试模式 避免出错,错误信息展示出来了,容易导致引发安全问题

ALLOWED_HOSTS = []

# 允许访问的IP

# 当我们将DEBUG 设置为False的时候,只有这个列表里面的IP才能访问django项目

# 一般我们会将服务器的IP放在里面

# 如果是 * 就表示允许所有的IP 进行访问

# Application definition

# 是个列表,列表的每一项是 安装了的APP 默认安装的APP

# sys.path 的列表 默认能找到

INSTALLED_APPS = [

'django.contrib.admin', # 自带的admin管理后台

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions', # 使用Session

'django.contrib.messages',

'django.contrib.staticfiles', # 静态文件

]

Django搭建个人博客Blog-Day02

# 中间件 按照从上往下的顺序 依次执行

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

]

# 告诉django路由文件的位置

ROOT_URLCONF = 'blog.urls'

# 模板相关的设置

TEMPLATES = [

{

# 使用的模板引擎是什么

'BACKEND': 'django.template.backends.django.DjangoTemplates',

# 是个列表 django会从这个列表中的每一项依次去找对应的模板文件

'DIRS': [],

# 默认为True 表示会从app里面去找 一个叫做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 = 'blog.wsgi.application'

# 数据库相关配置,当使用mysql数据库时需要更改此设置

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.sqlite3',

'NAME': os.path.join(BASE_DIR, '../../db.sqlite3'),

}

}

# 权限和密码认证相关设置

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

},

]

# 语言设置 默认是英文

# 想改成简体中文

LANGUAGE_CODE = 'zh-hans'

# LANGUAGE_CODE = 'en-us'

# 时区的设置 默认是UTC世界标准时间

# 想改成东八区

TIME_ZONE = 'Asia/Shanghai'

# TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

# 设置是否采用时区

# 如果是True 会保留时区的设置 在数据库保存的时间是带时区的

# 设置为False 就不会保存时区 在数据库就是本地时间

USE_TZ = False

# USE_TZ = True

Django搭建个人博客Blog-Day02

日志记录

在项目上线以后,要关闭调试模式,避免引起安全攻击,但是这样我们就看不到一些信息了,在实际中,我们的项目上线后可能还会遇到问题的,所以我们应该要将这些问题记录下来才对,并且应该记录一些用户的请求记录记录下来,方便后续运营人员做分析,运维人员做问题分析等等,所以要求我们将一些信息记录在指定的文件中。

  1. 在blog/blog/下创建一个文件夹:logs
  1. 在setting/dev.py文件中添加如下代码

# 用django记录日志

LOGGING = {

'version': 1, # 日志版本

'disable_existing_loggers': False, # 是否禁用已经存在的日志器

'formatters': { # 日志信息显示的格式

'verbose': { # 复杂的信息

'format': '%(levelname)s %(asctime)s %(module)s %(lineno)d %(message)s'

},

'simple': {

'format': '%(levelname)s %(module)s %(lineno)d %(message)s'

},

},

'filters': { # 对日志进行过滤

'require_debug_true': { # django在debug模式下才输出日志

'()': 'django.utils.log.RequireDebugTrue',

},

},

'handlers': { # 日志处理方法

'console': { # 向终端中输出日志

'level': 'INFO',

'filters': ['require_debug_true'],

'class': 'logging.StreamHandler',

'formatter': 'simple'

},

'file': { # 向文件中输出日志

'level': 'INFO',

'class': 'logging.handlers.RotatingFileHandler',

'filename': os.path.join(BASE_DIR, 'logs/debug.log'), # 日志文件的位置

'maxBytes': 300 * 1024 * 1024, # 300M

'backupCount': 10, # 10份文件

'formatter': 'verbose'

},

},

'loggers': { # 日志器

'django': { # 定义了一个名为django的日志器

'handlers': ['console', 'file'], # 可以同时向终端与文件中输出日志

'propagate': True, # 是否继续传递日志信息

'level': 'INFO', # 日志器接收的最低日志级别

},

}

}

这样,项目执行的日志记录信息都会保存在logs文件夹下

Django搭建个人博客Blog-Day02

配置静态文件

  1. 在blog/blog里面创建一个叫做static的文件夹,用来存放css等静态文件
  1. 在dev.py文件中添加如下代码:

# 配置静态文件的文件夹位置

STATICFILES_DIRS = [

os.path.join(BASE_DIR,'static')

]

配置模板文件位置

  1. 在blog/blog里面创建一个叫做templates的文件夹
  1. 在dev.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',

],

},

},

]

可以鼠标选中templates,右键选择make Directory as--->Templates Folder,这样就可以在其他程序中输入templates文件夹里的文件时拥有代码提示了。

创建apps

为了方便管理,(例如以后可能有多个版本等等问题),在blog\blog里面创建一个apps的软件包,以后所有的app都放在这个包里面,方便管理。

创建user的app

# 创建user的app的命令:python manage.py startapp user

# 这条命令在哪里运行的,就会在当前的路径下创建这个app

# 我们需要先进入虚拟环境,再cd到blog/blog/apps文件夹下,执行以下命令创建user

python ../../manage.py startapp user

# 因为要依赖manage.py文件创建app,所以要指定manage.py的位置,所以要使用“../../manage.py”

创建了app后,要在配置文件中告诉Django

追加导包路径

在dev.py文件中进行如下设置:

import sys # 新增代码

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

sys.path.append(os.path.join(BASE_DIR,'apps')) # 新增代码 追加导包路径

INSTALLED_APPS = [

...

'user', #在该列表的最后添加新增加的app名称

]

由中进行路由分发

在blog/urls.py文件中进行设置

from django.contrib import admin

from django.urls import path,include

urlpatterns = [

path('admin/', admin.site.urls),

# 进行路由分发

path('user',include('user.urls')),

]

在user文件夹中创建urls.py文件,进行路由设置:

from django.contrib import admin

from django.urls import path,include

urlpatterns = [

path('admin/', admin.site.urls),

# 进行路由分发

path('user',include('user.urls')),

]

当前项目结构:

blog

blog

settings

- dev.py (就是以前的Settings.py 作为开发环境的配置)

- prod.py (作为以后上线的环境配置)

apps (新增的包 用来存放app)

user 的应用

logs (新增的文件夹 用来存在日志信息)

templates (新增的文件夹 用来存在模板文件)

static (新增的文件夹 用来存在静态资源)

-wsgi.py (部署文件 做了修改)

- manage.py # 项目启动文件 (做了修改)

Django搭建个人博客Blog-Day02