Django商城專案筆記No.2專案準備工作
Django商城專案筆記No.2專案準備工作
接著上篇開始,建立好工程之後,隨之而來的是怎麼配置工程,這篇文章記錄如何進行相關的配置
1.pycharm開啟工程,進行相關的配置
通過pycharm開啟md_mall,然後進行下面的操作
2.調整工程目錄
建立python包docs , logs , scripts
在子 md_mall 目錄下建立包 apps , libs , settings , utils
並且在將 settings.py 拖到 settings 資料夾中改名字為 dev.py
3.在apps目錄下建立應用users
4.修改工程導包路徑
註冊應用
修改 manage.py 中的 settings.py 的檔案路徑
增加啟動引數
5.資料庫與 Redis 配置
5.1 資料庫
建立資料庫
create database md_mall default charset=utf8;
並且建立使用者
create user md_mall identified by 'md_mall'; grant all on md_mall.* to 'md_mall'@'%'; flush privileges;
配置資料庫:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1',# 資料庫主機 'PORT': 3306,# 資料庫埠 'USER': 'md_mall',# 資料庫使用者名稱 'PASSWORD': 'md_mall',# 資料庫使用者密碼 'NAME': 'md_mall'# 資料庫名字 } }
還要配置一個
5.2.redis
安裝redis
pip install django-redis
配置redis
# redis CACHES = { "default": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/0", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } }, "session": { "BACKEND": "django_redis.cache.RedisCache", "LOCATION": "redis://127.0.0.1:6379/1", "OPTIONS": { "CLIENT_CLASS": "django_redis.client.DefaultClient", } } } # 給admin站點使用的session SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "session"
注意 :我們在專案中不在使用 session 保持使用者狀態,而使用 jwt ,那為啥還要配置 redis 儲存 session 呢?是因為 admin 站點還要用 session 保持使用者狀態。
說明: 這裡配置兩個 redis , default 是資料快取到 redis , session 就是保持 session 到 redis
6. 日誌與異常配置
6.1.時區配置
LANGUAGE_CODE = 'zh-hans' TIME_ZONE = 'Asia/Shanghai'
6.2.日誌配置
# 日誌配置 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': 'DEBUG', 'filters': ['require_debug_true'], 'class': 'logging.StreamHandler', 'formatter': 'simple' }, 'file': {# 向檔案中輸出日誌 'level': 'INFO', 'class': 'logging.handlers.RotatingFileHandler', 'filename': os.path.join(os.path.dirname(BASE_DIR), "logs/meiduo.log"),# 日誌檔案的位置 'maxBytes': 300 * 1024 * 1024, 'backupCount': 10, 'formatter': 'verbose' }, }, 'loggers': {# 日誌器 'django': {# 定義了一個名為django的日誌器 'handlers': ['console', 'file'],# 可以同時向終端與檔案中輸出日誌 'propagate': True,# 是否繼續傳遞日誌資訊 'level': 'DEBUG',# 日誌器接收的最低日誌級別 }, } }
6.3.異常配置
在utils資料夾下新建檔案 exceptions.py
from rest_framework.views import exception_handler as drf_exception_handler import logging from django.db import DatabaseError from redis.exceptions import RedisError from rest_framework.response import Response from rest_framework import status # 獲取在配置檔案中定義的logger,用來記錄日誌 logger = logging.getLogger('django') def exception_handler(exc, context): """ 自定義異常處理 :param exc: 異常 :param context: 丟擲異常的上下文 :return: Response響應物件 """ # 呼叫drf框架原生的異常處理方法 response = drf_exception_handler(exc, context) if response is None: view = context['view'] if isinstance(exc, DatabaseError) or isinstance(exc, RedisError): # 資料庫異常 logger.error('[%s] %s' % (view, exc)) response = Response({'message': '伺服器內部錯誤'}, status=status.HTTP_507_INSUFFICIENT_STORAGE) return response
然後在配置檔案裡新增配置
REST_FRAMEWORK = { # 異常處理 'EXCEPTION_HANDLER': 'meiduo_mall.utils.exceptions.exception_handler', }
7.pycharm提示設定
7.1.js版本配置
開啟一個js檔案,發現有報錯
這是因為這些語法是在js6 版本才出現的,但是 pycharm 預設的是 5.1.
所以修改如下 :