創(chuàng)新互聯www.cdcxhl.cn八線動態(tài)BGP香港云服務器提供商,新人活動買多久送多久,劃算不套路!
成都創(chuàng)新互聯公司-專業(yè)網站定制、快速模板網站建設、高性價比信州網站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式信州網站制作公司更省心,省錢,快速模板網站建設找我們,業(yè)務覆蓋信州地區(qū)。費用合理售后完善,十年實體公司更值得信賴。這篇文章將為大家詳細講解有關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字典來獲取提交的值。(補充上節(jié)的內容)
同時新加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,百度一下發(fā)現這是跨站請求偽造,其實就是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的使用方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
文章名稱:django里post的使用方法-創(chuàng)新互聯
文章源于:http://muchs.cn/article22/cospcc.html
成都網站建設公司_創(chuàng)新互聯,為您提供網站策劃、全網營銷推廣、標簽優(yōu)化、網站制作、Google、響應式網站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯