您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關django里post的使用方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
POST傳遞參數
表單Post最簡單最基本的傳遞方式,我們先來學習如何使用表單來Post參數。我們先在目錄下新建templates文件夾,然后在該目錄下新建post.html,代碼如下:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>POST Params</title></head><body><form method="post" > UserName:<input type="text" name="username"/> Password:<input type="password" name="password"/> <input type="submit" value="Submit"> </form></body></html>
然后我們在settings.py里配置模板路徑
#1.8版本前TEMPLATE_DIRS={ os.path.join(BASE_DIR,'app/templates') }#1.8版本后TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', # templates 文件夾路徑 'DIRS': [os.path.join(BASE_DIR,'HelloDjango/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', ], }, }, ]
然后我們在views.py下新加函數params_post,代碼如下
def params_post(request): if request.method=='GET': return render(request,'post.html') else: username=request.POST.get('username','') password=request.POST.get('password','') return HttpResponse('username='+username+"&password="+password)
method是request的一個屬性,用來判斷提交方法,如果是GET方式提交,我們渲染界面返回,如果是POST方式提交,我們獲取提交參數并返回,可以看到post獲取參數和get類似,也是會有一個POST字典,我們通過key來獲取對應的值(對應表單里的name)。
對于上訴代碼,其實表單也可以以get方式提交,只需要將method屬性設置為get即是以get方式進行提交,此時在view函數中我們需要通過GET字典來獲取提交的值。(補充上節的內容)
同時新加url攔截post/,urls.py代碼如下
from django.conf.urls import patterns, include, urlfrom django.contrib import adminfrom app.views import params_test, params_test_reg, params_post urlpatterns = patterns('', # Examples: # url(r'^$', 'PostParams.views.home', name='home'), # url(r'^blog/', include('blog.urls')), url(r'^admin/', include(admin.site.urls)), url(r'^params_test/$',params_test), url(r'^params_test_reg/str(?P<str>\w+)page(?P<page>\d+)/$',params_test_reg), url(r'^post/$',params_post), )
然后啟動服務器,打開瀏覽器,輸入用戶名和密碼點擊提交,即會成功,ohno,即會出現以下錯誤界面
我們先別著急,先來分析下出現錯誤的原因,CSRF,百度一下發現這是跨站請求偽造,其實就是Django已經幫我們做了CSRF驗證,我們在做POST提交時候需要加上csrf_token(就是一個隨機碼)來完成csrf驗證,那該如何解決這個錯誤,我們來修改post.html代碼,如下
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>POST Params</title> </head> <body> <form method="post" > {%csrf_token%}//csrf_token用來驗證 UserName:<input type="text" name="username"/> Password:<input type="password" name="password"/> <input type="submit" value="Submit"> </form> </body> </html>
我們重新啟動服務器,再次提交參數即可看到成功界面。
關于django里post的使用方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。