Python Django搭建網(wǎng)站流程圖解
1. 創(chuàng)建Django REST framework工程
1.1手動(dòng)創(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 存放第三方的庫(kù)文件settings 存放配置文件的目錄,分為開(kāi)發(fā)dev和線上produtils 存放項(xiàng)目自己定義的公共函數(shù)或類(lèi)等docs 用于存放一些說(shuō)明文檔資料
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)建一個(gè)應(yīng)用,比如users,那么在配置文件的INSTALLED_APPS中注冊(cè)應(yīng)用應(yīng)該如下:
INSTALLED_APPS = [ ... ’web_project.apps.users.apps.UsersConfig’,]
為了還能像如下方式簡(jiǎn)便的注冊(cè)引用,我們需要向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ù)庫(kù)配置
采用mysql數(shù)據(jù)庫(kù)
DATABASES = { ’default’: { ’ENGINE’: ’django.db.backends.mysql’, ’HOST’: ’127.0.0.1’, # 數(shù)據(jù)庫(kù)主機(jī) ’PORT’: 3306, # 數(shù)據(jù)庫(kù)端口 ’USER’: ’caicai’, # 數(shù)據(jù)庫(kù)用戶(hù)名 ’PASSWORD’: ’caicai’, # 數(shù)據(jù)庫(kù)用戶(hù)密碼 ’NAME’: ’web_project’ # 數(shù)據(jù)庫(kù)名字 }}
注意:
記得在/web_project/web_project/__init__.py文件中添加
import pymysqlpymysql.install_as_MySQLdb()
進(jìn)入mysql數(shù)據(jù)庫(kù),為項(xiàng)目創(chuàng)建數(shù)據(jù)庫(kù)
create user caicai identified by ’caicai’; 創(chuàng)建用戶(hù)賬號(hào) meiduo, 密碼 meiduo (由identified by 指明)grant all on web_project.* to ’caicai’@’%’; 授權(quán)web_project數(shù)據(jù)庫(kù)下的所有表(web_project.*)的所有權(quán)限(all)給用戶(hù)caicai在以任何ip訪問(wèn)數(shù)據(jù)庫(kù)的時(shí)候(’caicai’@’%’)flush privileges; 刷新生效用戶(hù)權(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庫(kù)。
同時(shí)修改了Django的Session機(jī)制使用redis保存,且使用名為’session’的redis配置。
此處修改Django的Session機(jī)制存儲(chǔ)主要是為了給Admin站點(diǎn)使用。
關(guān)于django-redis 的使用,說(shuō)明文檔可見(jiàn)http://django-redis-chs.readthedocs.io/zh_CN/latest/
2.6本地化語(yǔ)言和時(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ù)庫(kù)異常和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,用來(lái)記錄日志logger = logging.getLogger(’django’)def exception_handler(exc, context): ''' 自定義異常處理 :param exc: 異常 :param context: 拋出異常的上下文 :return: Response響應(yīng)對(duì)象 ''' # 調(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ù)庫(kù)異常 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’,}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. idea設(shè)置提示不區(qū)分大小寫(xiě)的方法2. IntelliJ IDEA設(shè)置默認(rèn)瀏覽器的方法3. HTTP協(xié)議常用的請(qǐng)求頭和響應(yīng)頭響應(yīng)詳解說(shuō)明(學(xué)習(xí))4. CentOS郵件服務(wù)器搭建系列—— POP / IMAP 服務(wù)器的構(gòu)建( Dovecot )5. IntelliJ IDEA創(chuàng)建web項(xiàng)目的方法6. .NET SkiaSharp 生成二維碼驗(yàn)證碼及指定區(qū)域截取方法實(shí)現(xiàn)7. docker容器調(diào)用yum報(bào)錯(cuò)的解決辦法8. VMware中如何安裝Ubuntu9. IntelliJ IDEA導(dǎo)入項(xiàng)目的方法10. django創(chuàng)建css文件夾的具體方法
