真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求-創(chuàng)新互聯(lián)

怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

專注于為中小企業(yè)提供網(wǎng)站建設(shè)、成都網(wǎng)站制作服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)盤錦免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

自定義模版路徑及創(chuàng)建模版

編緝django1/django1/setting.py,定位到TEMPLATES變量,將DIRS的值修改為BASE_DIR+"/django1/templates",

在django1/django1目錄下創(chuàng)建templates文件夾,并在其下創(chuàng)建get.html、post.html、result.html三個(gè)文件。

get.html,用于get提交:





get請(qǐng)求示例


  
    
    
  

post.html,用于post提交。{%%}表示其內(nèi)是Django模板語句,{% csrf_token %}指示此表單加載時(shí)返回token在其提交時(shí)進(jìn)行token認(rèn)證(如果要關(guān)閉服務(wù)端該csrf附御功能將setting.py----MIDDLEWARE----'django.middleware.csrf.CsrfViewMiddleware'注釋掉):





post請(qǐng)求示例


  
    {% csrf_token %}
    
    
  

result.html,用于顯示get和post輸入的內(nèi)容。{{}}表示其內(nèi)是Django模板變量:

{{ result }}

2.2 配置請(qǐng)求路由

Django所有請(qǐng)求路由都由urls.py設(shè)置,即便是存在的靜態(tài)文件(如html)也要配置路由才能訪問。

編緝django1/django1/urls.py,修改為以下內(nèi)容:

from django.contrib import admin
from django.urls import path
from django.conf.urls import url
from . import view

urlpatterns = [
  path('admin/', admin.site.urls),
  # url(r'^hello$', view.hello),
  url(r'^get\.html$', view.get_html),
  url(r'^get$', view.get),
  url(r'^post\.html$', view.post_html),
  url(r'^post$', view.post),
]

2.3 實(shí)現(xiàn)處理邏輯

在2.2中我們配置了get.html、get、post.html、post四個(gè)請(qǐng)求分別轉(zhuǎn)交到view.get_html、view.get、view.post_html、view.post進(jìn)行處理。本節(jié)我們實(shí)現(xiàn)這四個(gè)處理邏輯。

在django1/django1文件夾下創(chuàng)建view.py,寫入以下內(nèi)容:

from django.shortcuts import render, render_to_response

def get_html(request):
  return render_to_response('get.html')

def get(request):
  context = {}
  # 通過request.GET['name']形式獲取get表單內(nèi)容
  # result為重定向到的result.html所使用的變量
  context['result'] = f"你搜索的內(nèi)容為:{request.GET['q']}"
  return render(request, 'result.html', context)

def post_html(request):
  # 不能和get一樣使用render_to_response必須使用render進(jìn)行重定向,不然服務(wù)端不會(huì)設(shè)置csrf_token
  # return render_to_response('post.html')
  return render(request, 'post.html')

def post(request):
  context = {}
  # 通過request.GET['name']形式獲取post表單內(nèi)容
  # result為重定向到的result.html所使用的變量
  context['result'] = f"你搜索的內(nèi)容為:{request.POST['q']}"
  return render(request, 'result.html', context)

其中注意如注釋所強(qiáng)調(diào),post_html中不能使用render_to_response必須使用render進(jìn)行重定向,不然服務(wù)器不能成功返回token導(dǎo)致token驗(yàn)證失敗進(jìn)而導(dǎo)致不能訪問頁面(403,CSRF token missing or incorrect.)。如下圖所示:

怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求

另外,如上所示返回了詳細(xì)的錯(cuò)誤信息,這在信息安全中是忌諱但這并不是django沒考濾到,而是Django默認(rèn)開啟DEBUG模式,到settings.py中設(shè)置DEBUG = False,并設(shè)置ALLOWED_HOSTS即可(ALLOWED_HOSTS不是指允許訪問服務(wù)的IP而是允許外部訪問服務(wù)地址)。

怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求

三、運(yùn)行效果

3.1 總體目錄結(jié)構(gòu)

經(jīng)第二大節(jié)所有操作,項(xiàng)目目錄結(jié)構(gòu)如下圖所示(.idea和__pycache__不用管):

怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求

看完上述內(nèi)容,你們掌握怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


分享題目:怎么在Python3中使用Django實(shí)現(xiàn)一個(gè)get/post請(qǐng)求-創(chuàng)新互聯(lián)
文章出自:http://weahome.cn/article/eoihc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部