歡迎您光臨本站 註冊首頁

Python Django搭建網站流程圖解

←手機掃碼閱讀     f2h0b53ohn @ 2020-06-14 , reply:0

1. 創建Django REST framework工程

1.1手動創建工程文件夾

1.2進去工程文件夾內,執行命令:django-admin startproject web_project創建工程目錄

1.3修改,添加目錄結構

apps 存放Django的應用libs 存放第三方的庫文件settings 存放配置文件的目錄,分為開發dev和線上produtils 存放項目自己定義的公共函數或類等docs 用於存放一些說明文檔資料

2.

修改配置文件

2.1 將Django工程中的settings.py文件拷貝到新創建的settings目錄下,並重命名為dev.py,並修改入口文件manage.py文件中配置文件路徑。

2.2修改settings/dev.py 文件中的路徑信息

我們將Django的應用放到了工程目錄/web_project/apps目錄下,如果創建一個應用,比如users,那麼在配置文件的INSTALLED_APPS中註冊應用應該如下:

  INSTALLED_APPS = [    ...    'web_project.apps.users.apps.UsersConfig',  ]

 

為了還能像如下方式簡便的註冊引用,我們需要向Python解釋器的導包路徑中添加apps應用目錄的路徑。

  INSTALLED_APPS = [    ...    'users.apps.UsersConfig',  ]

 

我們將配置文件改為放在settings子目錄下,所以 配置文件中的BASE_DIR指向的變為了工程目錄/web_project/web_project/web_project.

使用sys.path添加/apps目錄,即可添加apps應用的導包路徑。

  # Build paths inside the project like this: os.path.join(BASE_DIR, ...)  BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))    # 添加導包路徑  import sys  sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))

 

2.3INSTALLED_APPS

pip install djangorestframework

在INSTALLED_APPS中添加rest_framework

  INSTALLED_APPS = [    ...    'rest_framework',  ]

 

2.4數據庫配置

採用mysql數據庫

  DATABASES = {    'default': {      'ENGINE': 'django.db.backends.mysql',      'HOST': '127.0.0.1', # 數據庫主機      'PORT': 3306, # 數據庫端口      'USER': 'caicai', # 數據庫用戶名      'PASSWORD': 'caicai', # 數據庫用戶密碼      'NAME': 'web_project' # 數據庫名字    }  }

 

注意:

記得在/web_project/web_project/__init__.py文件中添加

import pymysqlpymysql.install_as_MySQLdb()

進入mysql數據庫,為項目創建數據庫

  create user caicai identified by 'caicai'; 創建用戶賬號 meiduo, 密碼 meiduo (由identified by 指明)  grant all on web_project.* to 'caicai'@'%'; 授權web_project數據庫下的所有表(web_project.*)的所有權限(all)給用戶caicai在以任何ip訪問數據庫的時候('caicai'@'%')  flush privileges; 刷新生效用戶權限

 

2.5安裝django-redis,並配置

執行命令進行安裝:pip install django-redis

  CACHES = {    "default": {      "BACKEND": "django_redis.cache.RedisCache",      "LOCATION": "redis://10.211.55.5:6379/0",      "OPTIONS": {        "CLIENT_CLASS": "django_redis.client.DefaultClient",      }    },    "session": {      "BACKEND": "django_redis.cache.RedisCache",      "LOCATION": "redis://10.211.55.5:6379/1",      "OPTIONS": {        "CLIENT_CLASS": "django_redis.client.DefaultClient",      }    }  }  SESSION_ENGINE = "django.contrib.sessions.backends.cache"  SESSION_CACHE_ALIAS = "session"

 

除了名為default的redis配置外,還補充了名為session的redis配置,分別使用兩個不同的redis庫。

同時修改了Django的Session機制使用redis保存,且使用名為'session'的redis配置。

此處修改Django的Session機制存儲主要是為了給Admin站點使用。

關於django-redis 的使用,說明文檔可見http://django-redis-chs.readthedocs.io/zh_CN/latest/

2.6本地化語言和時區

LANGUAGE_CODE = 'zh-hans'

TIME_ZONE = 'Asia/Shanghai'

2.7日誌

  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.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/web_project.log"), # 日誌文件的位置        'maxBytes': 300 * 1024 * 1024,        'backupCount': 10,        'formatter': 'verbose'      },    },    'loggers': {      'django': { # 定義了一個名為django的日誌器        'handlers': ['console', 'file'],        'propagate': True,      },    }  }

 

2.8異常處理

修改Django REST framework的默認異常處理方法,補充處理數據庫異常和Redis異常。

新建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': 'web_project.utils.exceptions.exception_handler',  }

  


[f2h0b53ohn ] Python Django搭建網站流程圖解已經有237次圍觀

http://coctec.com/docs/python/shhow-post-238526.html