Python-Django搭建網站流程


1. 創建Django REST framework工程

1.1手動創建工程文件夾

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

1.3修改,添加目錄結構

  • apps 存放Django的應用
  • libs 存放第三方的庫文件
  • settings 存放配置文件的目錄,分為開發dev和線上prod
  • utils 存放項目自己定義的公共函數或類等
  • 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添加<BASE_DIR>/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.3 INSTALLED_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 pymysql

pymysql.install_as_MySQLdb()

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

create database web_project default charset=utf8;

為本項目創建數據庫用戶(不再使用root賬戶)
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',
}

3.實現第一個app應用

-----待補充

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM