Python3+Django get/post請(qǐng)求實(shí)現(xiàn)教程詳解
之前寫了一篇“Python3+PyCharm+Django+Django REST framework開發(fā)教程 ”,想著直接介紹rest就完了。但回過頭來(lái)看,一是rest在解耦的同時(shí)將框架復(fù)雜化了如果沒有多終端那rest根本沒有降低復(fù)雜度反而增加了復(fù)雜度,二是基礎(chǔ)的get和post實(shí)現(xiàn)自己還是看半天。所以還是有必要再寫一篇來(lái)介紹django常規(guī)的MVC開發(fā)。
環(huán)境搭建程項(xiàng)目創(chuàng)建都類似的的rest化部分之前(2.5及之前)進(jìn)行操作即可,就不重復(fù)說明了。這里我創(chuàng)建的項(xiàng)目為django1,初始目錄結(jié)構(gòu)如下
如果自己創(chuàng)建的項(xiàng)目不叫django1,則以下所有django1修改為自己的項(xiàng)目名。
2.1 自定義模版路徑及創(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提交:
<!DOCTYPE html><html><head><meta charset='utf-8'><title>get請(qǐng)求示例</title></head><body> <form action='/get' method='get'> <input type='text' name='q' /> <input type='submit' value='搜索' /> </form></body></html>
post.html,用于post提交。{%%}表示其內(nèi)是Django模板語(yǔ)句,{% csrf_token %}指示此表單加載時(shí)返回token在其提交時(shí)進(jìn)行token認(rèn)證(如果要關(guān)閉服務(wù)端該csrf附御功能將setting.py----MIDDLEWARE----’django.middleware.csrf.CsrfViewMiddleware’注釋掉):
<!DOCTYPE html><html><head><meta charset='utf-8'><title>post請(qǐng)求示例</title></head><body> <form action='/post' method='post'> {% csrf_token %} <input type='text' name='q' /> <input type='submit' value='搜索' /> </form></body></html>
result.html,用于顯示get和post輸入的內(nèi)容。{{}}表示其內(nèi)是Django模板變量:
<h1>{{ result }}</h1>2.2 配置請(qǐng)求路由
Django所有請(qǐng)求路由都由urls.py設(shè)置,即便是存在的靜態(tài)文件(如html)也要配置路由才能訪問。
編緝django1/django1/urls.py,修改為以下內(nèi)容:
from django.contrib import adminfrom django.urls import pathfrom django.conf.urls import urlfrom . import viewurlpatterns = [ 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_responsedef 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)致不能訪問頁(yè)面(403,CSRF token missing or incorrect.)。如下圖所示:
另外,如上所示返回了詳細(xì)的錯(cuò)誤信息,這在信息安全中是忌諱但這并不是django沒考濾到,而是Django默認(rèn)開啟DEBUG模式,到settings.py中設(shè)置DEBUG = False,并設(shè)置ALLOWED_HOSTS即可(ALLOWED_HOSTS不是指允許訪問服務(wù)的IP而是允許外部訪問服務(wù)地址)。
經(jīng)第二大節(jié)所有操作,項(xiàng)目目錄結(jié)構(gòu)如下圖所示(.idea和__pycache__不用管):
get請(qǐng)求頁(yè)面:
get請(qǐng)求結(jié)果:
post請(qǐng)求頁(yè)面:
post請(qǐng)求結(jié)果:
本文主要介紹了Django中g(shù)et/post請(qǐng)求實(shí)現(xiàn)簡(jiǎn)單方法,想了解更多關(guān)于Django的使用教程請(qǐng)查看下面的相關(guān)鏈接
相關(guān)文章:
1. Intellij IDEA 2020.3 配置教程詳解2. idea給項(xiàng)目打war包的方法步驟3. IntelliJ IDEA刪除類的方法步驟4. Python importlib模塊重載使用方法詳解5. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對(duì)象Application和Session)6. 兩行Javascript代碼生成UUID的方法7. IntelliJ IDEA設(shè)置編碼格式的方法8. 解決python中import文件夾下面py文件報(bào)錯(cuò)問題9. 使用 kind 和 Docker 啟動(dòng)本地的 Kubernetes環(huán)境10. XML入門精解之結(jié)構(gòu)與語(yǔ)法
