Django項目: 項目環境搭建 ---- 二、django項目設置

来源:https://www.cnblogs.com/Tmclri/archive/2019/09/12/11515365.html
-Advertisement-
Play Games

1.配置模板文件 2.配置mysql資料庫 創建資料庫 配置settings 方法一:直接在settings.py文件中添加資料庫配置信息 方法二:將資料庫配置信息存到一個文件,在settings文件中將其引入。(推薦) 新建資料庫配置文件db.cnf(名字隨意) db.cnf文件內容: 在sett ...


1.配置模板文件

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
            # 將模板標簽內置到模板中 https://docs.djangoproject.com/en/2.1/topics/templates/
            'builtins': ['django.templatetags.static'],
        },
    },
]

 

2.配置mysql資料庫

  1. 創建資料庫

    mysql> create database tzproject charset=utf8mb4;
    Query OK, 1 row affected (0.00 sec)
  2. 創建用戶
    mysql> create user 'dj_user'@'%' identified by 'pythonvip';
    Query OK, 1 row affected (0.00 sec)
  3. 授權
    mysql> grant all privileges on tzproject.* to 'dj_user'@'%';
    Query OK, 0 rows affected (0.03 sec)
    mysql> flush privileges;
    Query OK, 0 rows affected (0.02 sec)
    # 授權創建一起寫
    grant all privileges on tzproject.* to 'xinlan'@'%' identified by 'pythonvip'
  4. 配置settings

    方法一:直接在settings.py文件中添加資料庫配置信息

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',               # 資料庫引擎
            'NAME': 'tzproject',                                # 資料庫名
            'USER': 'dj_user',                                  # 用戶名
            'PASSWORD': 'pythonvip',                            # 密碼
            'HOST': '127.0.0.1',                                # 主機IP
            'PORT': 3306                                        #
        }
    }

    方法二:將資料庫配置信息存到一個文件,在settings文件中將其引入。(推薦)

    新建資料庫配置文件db.cnf(名字隨意)

    db.cnf文件內容:

    [client]
    database = tzproject
    user = dj_user
    password = pythonvip
    host = 127.0.0.1
    port = 3306
    default-character-set = utf8


    在settings.py文件中引入db.cnf

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'OPTIONS':{
                'read_default_file': 'utils/db/db.cnf',
            }
        }
    }


    官方文檔:https://docs.djangoproject.com/en/2.1/ref/databases/#connecting-to-the-database

3.安裝mysql資料庫的python驅動

⚠️mysql資料庫配置完成後,運行django服務會報如下錯誤,官方推薦安裝mysqlclient1.3.7以上版本,也可以安裝pymysql,並且需要在settings.py文件所在目錄包中的__init__.py中導入pymysql。

 

1. 安裝mysqlclient

# 首先更新ubuntu
sudo apt-get update 

# 然後按照依賴庫
sudo apt-get install default-libmysqlclient-dev

# 再切換到虛擬環境中
workon tzproject

# 最後安裝mysqlclient
pip install mysqlclient -i https://pypi.doubanio.com/simple

2.安裝pymysql

# 安裝pymysql
pip install pymysql -i https://pypi.doubanio.com/simple

  settings.py文件所在目錄下的__init__.py導入

 

 

推薦使用第一種方式,mysqlclient更快更安全,官方推薦。

4.配置redis緩存

用於存放用戶session信息,以及需要緩存的各種信息。

# 在虛擬機中安裝django-redis
pip install django-redis    
# settings.py文件中指定redis配置

CACHES = {
    "default": {
        "BACKEND": "django_redis.cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/0",
        "OPTIONS": {
            "CLIENT_CLASS": "django_redis.client.DefaultClient",
        }
    },
    'session': {
        'BACKEND': 'django_redis.cache.RedisCache',
        'LOCATION': 'redis://127.0.0.1:6379/1',
        'OPTIONS': {
            'CLIENT_CLASS': 'django_redis.client.DefaultClient',
        }
    },
}

# session存儲緩存設置
SESSION_ENGINE = 'django.contrib.sessions.backends.cache'
SESSION_CACHE_ALIAS = 'session'

文檔地址:https://django-redis-chs.readthedocs.io/zh_CN/latest/

django文檔:https://docs.djangoproject.com/en/2.2/topics/http/sessions/#using-cached-sessions

5.配置日誌器

用於記錄系統運行過程中的各種日誌信息。

在項目根目錄中創建一個logs文件夾,用於存放日誌文件

# 日誌
LOGGING = {
    # 版本
    'version': 1,
    # 是否禁用已存在的日誌器
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '{levelname} {asctime} {module} {lineno:d} {message}',
            'style': '{',
        },
        'simple': {
            'format': '{levelname} {module} {lineno:d} {message}',
            'style': '{',
        },
    },
    'filters': {
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },
    'handlers': {
        'console': {
            'level': 'DEBUG',
            'filters': ['require_debug_true'],
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
        'file': {
            'level': 'INFO',
            # 這個handler可以記錄一組日誌文件
            'class': 'logging.handlers.RotatingFileHandler',
            'filename': os.path.join(BASE_DIR, 'logs/tz_django.log'),
            # 單個日誌文件最大位元組數
            'maxBytes': 300*1024*1024,
            # 日誌文件個數
            'backupCount': 10,
            'formatter': 'verbose'
        },
    },
    'loggers': {
        'django': {
            'handlers': ['console', 'file'],
            'level': 'INFO',  # 日誌器接收的最低級別
            'propagate': True,
        },
    },
}

使用方法

# 使用方法
# import the logging library
import logging

# Get an instance of a logger
# 此處的django為,settings.py文件中,LOGGING配置下的loggers中定義的日誌器名稱
logger = logging.getLogger('django')    

def my_view(request, arg1, arg):
    ...
    if ***:
        # Log an error message
        logger.error('Something went wrong!')

官方文檔:https://docs.djangoproject.com/en/2.2/topics/logging/#module-django.utils.log

6.時區配置

# 修改語言
LANGUAGE_CODE = 'zh-hans'
# 修改時區
TIME_ZONE = 'Asia/Shanghai'

USE_I18N = True

USE_L10N = True
# 使用時區
USE_TZ = True

7.靜態文件配置

在項目根目錄創建一個static目錄,用於存放靜態文件(css, js, image, font等)

STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR, 'static')
]

8.創建應用

本項目主要由4個模塊組成,分別為新聞文章模塊,課程視頻播放模塊,文檔下載模塊,用戶管理模塊等。在項目根目錄下創建一個apps目錄用於存放各子應用。

 

 然後cd到apps目錄創建各子應用

~$ cd ~/code/tztz/apps/
~/code/tztz/apps$ workon tzproject
(tzproject) ~/code/tztz/apps$ python ../manage.py startapp news
(tzproject) ~/code/tztz/apps$ python ../manage.py startapp course
(tzproject) ~/code/tztz/apps$ python ../manage.py startapp doc
(tzproject) ~/code/tztz/apps$ python ../manage.py startapp user

再到settings文件中,加入如下設置

import sys

# 創建應用之後,把apps目錄加入到sys.path中
sys.path.insert(0, BASE_DIR)
sys.path.insert(1, os.path.join(BASE_DIR, 'apps'))

接著分別在apps文件夾和項目根目錄文件夾上右鍵,加入到Source Root中,優化導入路徑(pycharm提示)。

 

 

 最後將應用添加到INSTALLED_APPS列表中

INSTALLED_APPS = [
    # ...
    'user',
    'news',
    'doc',
    'course'
]

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.nfs實現的原理解析? 2.安裝、配置、nfs服務 1.安裝 2.配置 3.根據配置進行初始化環境 4.啟動 5.客戶端測試 6.錯誤的示範 7.多個客戶端共用一個存儲伺服器 (NFS) 8.實現開機自動掛載(因為伺服器不重啟) 擴展瞭解即可 3.nfs相關的配置參數 4.rw 和 ro 2.驗 ...
  • 如何界定爬蟲的合法性,我通過翻閱大量文章、事件、分享、司法案例,總結出界定的三個關鍵點 ...
  • 併發編程 併發(偽):由於執行速度特別快,人感覺不到 並行(真):創建10個人同時操作 線程 1. 單進程,單線程的應用程式 print('666') 2. 到底什麼是線程?什麼是進程 Python自己沒有這玩意,Python中調用的操作系統的線程和進程(偽線程) 3. 多線程 工作的最小單元 共用 ...
  • 一、線程替代方案 1.subprocess (1)完全跳過線程,使用進程 (2)是派生進程的主要替代方案 (3)python2.4後引入 2.multiprocessing (1)使用threading介面派生,使用子進程 (2)允許為多核或者多CPU派生進程,介面很threading非常相似 (3 ...
  • 上一篇博客已經給大家介紹了一些演算法題,明天剛好是中秋了,這裡祝大家中秋快樂。剛好趕上數學建模了,今天就先介紹與衡量演算法水平的重要指標時間複雜度吧。在時間充裕情況下會更新5+2。之後還會介紹空間複雜度以及python內置函數的時間複雜度。 1.簡介 先看一下什麼是時間複雜度: 衡量代碼的好壞,包括兩個 ...
  • 一、序列化組件 簡單使用 開發我們的Web API的第一件事是為我們的Web API提供一種將代碼片段實例序列化和反序列化為諸如 之類的表示形式的方式。我們可以通過聲明與Django forms非常相似的序列化器(serializers)來實現。 models部分: views部分: ModelSe ...
  • 之前通過hook技術實現了微信pc端發送消息功能,如果在結合圖靈機器人就能實現微信聊天機器人。 代碼下載:http://blog.yshizi.cn/131.html 邏輯如下: ![捕獲.jpg][1] 下麵我簡單介紹一下步驟。 1. 首先,你需要下載我的微信助手,下載地址請參考我的博客文章: [ ...
  • arraylist源碼分析 1.數組介紹 數組是數據結構中很基本的結構,很多編程語言都內置數組,類似於數據結構中的線性表 在java中當創建數組時會在記憶體中劃分出一塊連續的記憶體,然後當有數據進入的時候會將數據按順序的存儲在這塊連續的記憶體中。當需要讀取數組中的數據時,需要提供數組中的索引,然後數組根據 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...