色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Python Django搭建網(wǎng)站流程圖解

瀏覽:36日期:2022-07-21 13:29:22

1. 創(chuàng)建Django REST framework工程

1.1手動創(chuàng)建工程文件夾

1.2進(jìn)去工程文件夾內(nèi),執(zhí)行命令:django-admin startproject web_project創(chuàng)建工程目錄

1.3修改,添加目錄結(jié)構(gòu)

apps 存放Django的應(yīng)用libs 存放第三方的庫文件settings 存放配置文件的目錄,分為開發(fā)dev和線上produtils 存放項(xiàng)目自己定義的公共函數(shù)或類等docs 用于存放一些說明文檔資料

Python Django搭建網(wǎng)站流程圖解2.

修改配置文件

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

Python Django搭建網(wǎng)站流程圖解

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

我們將Django的應(yīng)用放到了工程目錄/web_project/apps目錄下,如果創(chuàng)建一個(gè)應(yīng)用,比如users,那么在配置文件的INSTALLED_APPS中注冊應(yīng)用應(yīng)該如下:

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

為了還能像如下方式簡便的注冊引用,我們需要向Python解釋器的導(dǎo)包路徑中添加apps應(yīng)用目錄的路徑。

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

我們將配置文件改為放在settings子目錄下,所以 配置文件中的BASE_DIR指向的變?yōu)榱斯こ棠夸?web_project/web_project/web_project.

使用sys.path添加<BASE_DIR>/apps目錄,即可添加apps應(yīng)用的導(dǎo)包路徑。

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))# 添加導(dǎo)包路徑import syssys.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數(shù)據(jù)庫配置

采用mysql數(shù)據(jù)庫

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

注意:

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

import pymysqlpymysql.install_as_MySQLdb()

進(jìn)入mysql數(shù)據(jù)庫,為項(xiàng)目創(chuàng)建數(shù)據(jù)庫

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

2.5安裝django-redis,并配置

執(zhí)行命令進(jìn)行安裝: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配置外,還補(bǔ)充了名為session的redis配置,分別使用兩個(gè)不同的redis庫。

同時(shí)修改了Django的Session機(jī)制使用redis保存,且使用名為’session’的redis配置。

此處修改Django的Session機(jī)制存儲主要是為了給Admin站點(diǎn)使用。

關(guān)于django-redis 的使用,說明文檔可見http://django-redis-chs.readthedocs.io/zh_CN/latest/

2.6本地化語言和時(shí)區(qū)

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’: { # 定義了一個(gè)名為django的日志器 ’handlers’: [’console’, ’file’], ’propagate’: True, }, }}

2.8異常處理

修改Django REST framework的默認(rèn)異常處理方法,補(bǔ)充處理數(shù)據(jù)庫異常和Redis異常。

新建utils/exceptions.py

from rest_framework.views import exception_handler as drf_exception_handlerimport loggingfrom django.db import DatabaseErrorfrom redis.exceptions import RedisErrorfrom rest_framework.response import Responsefrom rest_framework import status# 獲取在配置文件中定義的logger,用來記錄日志logger = logging.getLogger(’django’)def exception_handler(exc, context): ''' 自定義異常處理 :param exc: 異常 :param context: 拋出異常的上下文 :return: Response響應(yīng)對象 ''' # 調(diào)用drf框架原生的異常處理方法 response = drf_exception_handler(exc, context) if response is None: view = context[’view’] if isinstance(exc, DatabaseError) or isinstance(exc, RedisError): # 數(shù)據(jù)庫異常 logger.error(’[%s] %s’ % (view, exc)) response = Response({’message’: ’服務(wù)器內(nèi)部錯(cuò)誤’}, status=status.HTTP_507_INSUFFICIENT_STORAGE) return response

配置文件中添加

REST_FRAMEWORK = { # 異常處理 ’EXCEPTION_HANDLER’: ’web_project.utils.exceptions.exception_handler’,}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产黄色片在线免费观看 | 99爱精品视频 | 萌白酱福利视频 | 久久久久久免费精品视频 | 韩日一级毛片 | 亚洲精品一区国产二区 | 另类二区三四 | 免费视频一区二区 | 手机看片免费基地 | 日韩精品亚洲专区在线观看 | 亚洲色色色图 | 九九综合九九 | 亚洲精品第一区二区在线 | 新版天堂中文资源官网 | 久久综合精品视频 | 亚洲天堂一区二区在线观看 | 日本一级做人免费视频 | 国产精品成人观看视频免费 | 在线观看欧美一区 | 成年人毛片视频 | 日韩欧美精品在线观看 | 自拍网在线 | 精品一精品国产一级毛片 | 国产在线播放一区 | 嫩模大尺度人体福利视频 | 一色屋成人免费精品网 | 91精品国产高清久久久久久91 | 日韩精品久久久毛片一区二区 | 日韩国产一区二区 | 亚洲国产成人在人网站天堂 | 亚洲高清在线看 | a天堂中文在线官网 | 欧美一级毛片欧美大尺度一级毛片 | 美女张开腿黄网站免费国产 | 99视频国产热精品视频 | 热伊人99re久久精品最新地 | 久久福利青草精品资源站免费 | 另类视频区第一页 | 未满14周岁啪啪网站 | 日本精品中文字幕有码 | 国产高清精品久久久久久久 |