推薦 2 款必備的 Django 開發神器

1. 前言

大家好,我是安果!

使用 Django 進行 Web 開發的時候,爲了提高開發效率,少不了安裝一些第三方應用 App

本篇文章將推薦 2 款非常好用的應用 App

  • django_extensions

  • debug_toolbar

2. django_extensions

django_extensions,是一個爲 Django 項目收集全局自定義管理擴展的存儲庫

首先,在目標虛擬環境下安裝依賴

# 安裝依賴
pip3 install django-extensions

然後,在項目的配置文件 settings.py 中添加 App

# settings.py

# 調試模式
DEBUG = True

# 新增App:django_extensions
INSTALLED_APPS =(
    ...
    'django_extensions',
    ...
)

接下來就可以使用它進行項目調試了

常見的功能如下:

2-1 增強版 Shell

我們都知道,原始項目都是使用「 ./manage.py shell 」命令進入到調試模式,涉及到模型 Model 操作都需要手動導入

然而,添加 django_extensions 應用後,直接使用「 ./manage.py shell_plus 」命令就可以進入到增強版的 Shell,自動導入項目下所有模型,非常方便我們調試

2-2 檢查模板錯誤

使用「 ./manage.py validate_templates 」命令可以檢測模板中的錯誤

# 檢查模板錯誤
(django) localhost:xh_tools xingag$ ./manage.py validate_templates
0 errors found

2-3 查看路由列表

使用「 ./manage.py show_urls 」命令可以查看項目所有的路由及視圖函數對應關係表

更多功能可以參考:

https://github.com/django-extensions/django-extensions

3. django_toolbar

django_toolbar,是一款 Django 開發利器,在 Debug 模式下,能實時展示項目的整體信息、請求響應、SQL、緩存等內容

首先,在虛擬環境下安裝依賴包

# 安裝依賴包
pip3 install django-debug-toolbar

然後,在項目配置文件 settings.py 中,對 django_toolbar 進行配置

3-1 添加應用

# settings.py

# 調試模式
DEBUG = True

# 新增App:django_extensions
INSTALLED_APPS =(
    ...
    'debug_toolbar',
    ...
)

3-2 啓用 django_toolbar 中間件

在 MIDDLEWARE 列表中,儘早的啓動 django_toolbar 中間件

注意:中間件的位置很重要,djano_toolbar 中間件必須位於對響應內容進行編碼的任何其他中間件之後

# settings.py

MIDDLEWARE = [
    'debug_toolbar.middleware.DebugToolbarMiddleware',
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.locale.LocaleMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
]

參考:

https://docs.djangoproject.com/en/dev/ref/middleware/#django.middleware.gzip.GZipMiddleware

3-3 配置內部 IP

必須要在配置文件 settings.py 設置 INTERNAL_IPS 的值爲本地 IP,纔會在網頁上展示調試工具欄

# settings.py

INTERNAL_IPS = [
    '127.0.0.1',
    'localhost'
]

3-4 配置顯示內容( 可選 )

默認工具欄展示所有內容,也可以定義 DEBUG_TOOLBAR_PANELS 列表的值,指定顯示部分內容

比如:僅配置加載時間、請求頭和響應頭、請求信息、SQL 語句、緩存、日誌信息

# settings.py

DEBUG_TOOLBAR_PANELS = [
    'debug_toolbar.panels.timer.TimerPanel',
    'debug_toolbar.panels.headers.HeadersPanel',
    'debug_toolbar.panels.request.RequestPanel',
    'debug_toolbar.panels.sql.SQLPanel',
    'debug_toolbar.panels.cache.CachePanel',
    'debug_toolbar.panels.logging.LoggingPanel',
]

最後,在項目下的 urls.py 文件內配置調試工具欄的 URL

# 項目下的urls.py

# 配置調試工具欄的URL
urlpatterns = [
    path('', include('index.urls')),
    path('admin/', admin.site.urls),

    # 設置項目上線的靜態資源路徑
    url('^static/(?P<path>.*)$', static.serve,
        {'document_root': settings.STATIC_ROOT}, name='static')
]

# 如果是調式狀態
if settings.DEBUG:
    import debug_toolbar

    urlpatterns = [
                      path('__debug__/', include(debug_toolbar.urls)),
                  ] + urlpatterns

以調試模式運行項目後,就可以在網頁上看到工具欄的實時信息了

更多功能可以參考:

https://github.com/jazzband/django-debug-toolbar

4. 最後

文中推薦了兩款非常實用的 Django 開發輔助應用,它可以幫助我們對項目進行調試,快速定位問題

如果你覺得文章還不錯,請大家 點贊、分享、留言 下,因爲這將是我持續輸出更多優質文章的最強動力!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章