99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁大數(shù)據(jù)時代推薦2款必備的Django開發(fā)神器
推薦2款必備的Django開發(fā)神器
2021-03-23
收藏

來源:AirPython

作者:星安果

推薦2款必備的Django開發(fā)神器

1. 前言

大家好,我是安果!

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

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

django_extensionsdebug_toolbar django_extensions

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

首先,在目標虛擬環(huán)境下安裝依賴

# 安裝依賴
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款必備的Django開發(fā)神器

2-2.檢查模板錯誤

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

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

2-3.查看路由列表

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

3. django_toolbar

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

首先,在虛擬環(huán)境下安裝依賴包

# 安裝依賴包
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',
]

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),
# 設置項目上線的靜態(tài)資源路徑
url('^static/(?P.*)$', static.serve,
{'document_root': settings.STATIC_ROOT}, name='static')
]
# 如果是調式狀態(tài)
if settings.DEBUG:
import debug_toolbar
urlpatterns = [
path('__debug__/', include(debug_toolbar.urls)),
] + urlpatterns

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

推薦2款必備的Django開發(fā)神器

4. 最后

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

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

SQL

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師考試動態(tài)
數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調,回調的第一個參數(shù)驗證碼對象,之后可以使用它調用相應的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }