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的應用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的應用放到了工程目錄/web_project/apps目錄下,如果創(chuàng)建一個應用,比如users,那么在配置文件的INSTALLED_APPS中注冊應用應該如下:
INSTALLED_APPS = [ ... 'web_project.apps.users.apps.UsersConfig', ]
為了還能像如下方式簡便的注冊引用,我們需要向Python解釋器的導包路徑中添加apps應用目錄的路徑。
INSTALLED_APPS = [ ... 'users.apps.UsersConfig', ]
我們將配置文件改為放在settings子目錄下,所以 配置文件中的BASE_DIR指向的變?yōu)榱斯こ棠夸?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.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響應對象
"""
# 調(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': '服務器內(nèi)部錯誤'}, status=status.HTTP_507_INSUFFICIENT_STORAGE)
return response
配置文件中添加
REST_FRAMEWORK = {
# 異常處理
'EXCEPTION_HANDLER': 'web_project.utils.exceptions.exception_handler',
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 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服務器部署與環(huán)境部署教程詳解
- Python Django路徑配置實現(xiàn)過程解析
相關(guān)文章
Python?pygame派生精靈和精靈組創(chuàng)建敵機
這篇文章主要為大家介紹了Python?pygame派生精靈和精靈組創(chuàng)建敵機示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-08-08
python 將數(shù)據(jù)保存為excel的xls格式(實例講解)
下面小編就為大家分享一篇python 將數(shù)據(jù)保存為excel的xls格式(實例講解),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
python調(diào)用OpenCV實現(xiàn)人臉識別功能
這篇文章主要為大家詳細介紹了python調(diào)用OpenCV實現(xiàn)人臉識別功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05
利用Python的folium包繪制城市道路圖的實現(xiàn)示例
這篇文章主要介紹了利用Python的folium包繪制城市道路圖的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-08-08
如何使用django-treebeard實現(xiàn)樹類型存儲與編輯
這篇文章主要介紹了使用django-treebeard實現(xiàn)樹類型存儲與編輯的宣相關(guān)操作代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-08-08

