django debug=false后静态文件丢失_python框架Django实战商城项目之工程搭建
項目說明
該電商項目類似于京東商城,主要模塊有驗證、用戶、第三方登錄、首頁廣告、商品、購物車、訂單、支付以及后臺管理系統。 項目開發模式采用前后端不分離的模式,為了提高搜索引擎排名,頁面整體刷新采用jinja2模板引擎實現,局部刷新采用vue.js實現。
項目運行機制如下:
項目搭建
工程創建
項目使用碼云進行源代碼版本控制,在碼云創建好后直接克隆到本地即可,然后在項目根目錄下執行virtualenv venv創建虛擬環境,source venv/bin/activat激活虛擬環境后,安裝django后,執行 django-admin startproject immortal_mall創建django工程。
配置開發環境
商城項目有兩個環境,分別為測試環境和開發環境,django項目在創建完成后只有一個settings配置文件,但是兩個環境需要兩個配置文件,這里需要修改django獲取配置文件的方式。新建settings包,再新建dev和pro兩個配置文件,將默認生成的settings文件里面的內容拷貝至dev和pro文件里,結果如下
再在mange.py文件里指定開發環境需要的配置文件,生成環境的后面再說
配置jiaja2模板引擎
安裝jinja2擴展包pip install jinja2,然后在dev文件中配置一下
這里有個注意的點,如果在運行的時候報錯了,提示
這時是因為注釋掉了django默認的模板配置,需要去掉注釋,只添加新的版本引起即可。
配置mysql數據庫
新建數據庫
配置數據庫
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'immortal_mall','HOST': '127.0.0.1','USER': 'zhouyajun','PASSWORD': '12345678','PORT': '3306'} }django默認使用的是mysqlclient工具,需要單獨安裝,這里用pymysql代替,在工程同名子目錄的__init__.py文件中,寫入下面代碼import pymysql pymysql.install_as_MySQLdb()在啟動項目對的時候可能會報錯,提示mysqlFile "/Users/lixiang/.env/lib/python3.6/site-packages/django/db/backends/mysql/base.py", line 36, in <module>raise ImproperlyConfigured('mysqlclient 1.3.13 or newer is required; you have %s.' % Database.__version__) django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.13 or newer is required; you have 0.9.3.具體解決方式可以參考這里https://zhuanlan.zhihu.com/p/76920424配置redis
商城采用redis作為緩存服務 pip install django-redis 這里是django-redis的使用文檔https://django-redis-chs.readthedocs.io/zh_CN/latest/,在dev文件中配置redis
緩存配置
CACHES = {"default": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://127.0.0.1:6379/2","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient",}},"session": {"BACKEND": "django_redis.cache.RedisCache","LOCATION": "redis://127.0.0.1:6379/3","OPTIONS": {"CLIENT_CLASS": "django_redis.client.DefaultClient",}} } SESSION_ENGINE = "django.contrib.sessions.backends.cache" SESSION_CACHE_ALIAS = "session"default是redis采用的默認配置,用的是2號數據庫,session是redis保持保持狀態的配置項,用的是3號數據庫,
日志配置
# 日志配置 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在debug模式下才輸出日志'()': 'django.utils.log.RequireDebugTrue',},},'handlers': { # 日志處理方法'console': { # 向終端中輸出日志'level': 'INFO','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/mall.log'), # 日志文件的位置'maxBytes': 300 * 1024 * 1024,'backupCount': 10,'formatter': 'verbose'},},'loggers': { # 日志器'django': { # 定義了一個名為django的日志器'handlers': ['console', 'file'], # 可以同時向終端與文件中輸出日志'propagate': True, # 是否繼續傳遞日志信息'level': 'INFO', # 日志器接收的最低日志級別},} }這里需要在項目的根目錄下手動創建logs文件,寫日志的時候呢,我們希望能夠自動分日期去寫,每天的日志寫到不同的文件里,這里可以使用python模塊自帶的TimedRotatingFileHandler,也可以自定義一個handler類去實現。 我這里呢自己實現了一個類叫做MallRotatingFileHandler 效果如下:
該類實現按月劃分日志文件,自動按照當天日期命名日志文件,也可以定義文件容量。
配置前端靜態文件
準備靜態文件夾static
指定靜態文件加載路徑
# 指定加載靜態恩建路由前綴 STATIC_URL = '/static/' # 配置靜態文件加載路徑 STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]運行項目,請求獲取一張圖片http://127.0.0.1:8989/static/images/adv01.jpg,成功獲取表示配置正確。
最終項目各個目錄展示成果:
歡迎大家去 我的博客 瞅瞅,里面有更多關于測試實戰的內容哦!!
總結
以上是生活随笔為你收集整理的django debug=false后静态文件丢失_python框架Django实战商城项目之工程搭建的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 百度网盘APP如何加好友(百度产品大全)
- 下一篇: 扫描全能王app怎么用(哪个扫描app最