Python Django搭建網(wǎng)站流程圖解
1. 創(chuàng)建Django REST framework工程
1.1手動創(chuàng)建工程文件夾
1.2進去工程文件夾內(nèi),執(zhí)行命令:django-admin startproject web_project創(chuàng)建工程目錄
1.3修改,添加目錄結(jié)構(gòu)
apps 存放Django的應(yīng)用libs 存放第三方的庫文件settings 存放配置文件的目錄,分為開發(fā)dev和線上produtils 存放項目自己定義的公共函數(shù)或類等docs 用于存放一些說明文檔資料
2.
修改配置文件
2.1 將Django工程中的settings.py文件拷貝到新創(chuàng)建的settings目錄下,并重命名為dev.py,并修改入口文件manage.py文件中配置文件路徑。
2.2修改settings/dev.py 文件中的路徑信息
我們將Django的應(yīng)用放到了工程目錄/web_project/apps目錄下,如果創(chuàng)建一個應(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 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數(shù)據(jù)庫配置
采用mysql數(shù)據(jù)庫
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'HOST': '127.0.0.1', # 數(shù)據(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()
進入mysql數(shù)據(jù)庫,為項目創(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ù)庫的時候('caicai'@'%') flush privileges; 刷新生效用戶權(quán)限
2.5安裝django-redis,并配置
執(zhí)行命令進行安裝: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站點使用。
關(guān)于django-redis 的使用,說明文檔可見http://django-redis-chs.readthedocs.io/zh_CN/latest/
2.6本地化語言和時區(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': { # 定義了一個名為django的日志器 'handlers': ['console', 'file'], 'propagate': True, }, } }
2.8異常處理
修改Django REST framework的默認異常處理方法,補充處理數(shù)據(jù)庫異常和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響應(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)部錯誤'}, status=status.HTTP_507_INSUFFICIENT_STORAGE) return response
配置文件中添加
REST_FRAMEWORK = { # 異常處理 'EXCEPTION_HANDLER': 'web_project.utils.exceptions.exception_handler', }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python自動化測試三部曲之request+django實現(xiàn)接口測試
- python3.7.3版本和django2.2.3版本是否可以兼容
- 基于CentOS搭建Python Django環(huán)境過程解析
- python+django+selenium搭建簡易自動化測試
- Python Django中間件使用原理及流程分析
- Python+Django+MySQL實現(xiàn)基于Web版的增刪改查的示例代碼
- Python3之外部文件調(diào)用Django程序操作model等文件實現(xiàn)方式
- Django+python服務(wù)器部署與環(huán)境部署教程詳解
- Python Django路徑配置實現(xiàn)過程解析
相關(guān)文章
Python?pygame派生精靈和精靈組創(chuàng)建敵機
這篇文章主要為大家介紹了Python?pygame派生精靈和精靈組創(chuàng)建敵機示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08python 將數(shù)據(jù)保存為excel的xls格式(實例講解)
下面小編就為大家分享一篇python 將數(shù)據(jù)保存為excel的xls格式(實例講解),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05python調(diào)用OpenCV實現(xiàn)人臉識別功能
這篇文章主要為大家詳細介紹了python調(diào)用OpenCV實現(xiàn)人臉識別功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05利用Python的folium包繪制城市道路圖的實現(xiàn)示例
這篇文章主要介紹了利用Python的folium包繪制城市道路圖的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08如何使用django-treebeard實現(xiàn)樹類型存儲與編輯
這篇文章主要介紹了使用django-treebeard實現(xiàn)樹類型存儲與編輯的宣相關(guān)操作代碼,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-08-08