以前寫了一篇「Python3+PyCharm+Django+Django REST framework開發教程 」,想着直接介紹rest就完了。但回過頭來看,一是rest在解耦的同時將框架複雜化了若是沒有多終端那rest根本沒有下降複雜度反而增長了複雜度,二是基礎的get和post實現本身仍是看半天。因此仍是有必要再寫一篇來介紹django常規的MVC開發。html
環境搭建程項目建立都相似的的rest化部分以前(2.5及以前)進行操做便可,就不重複說明了。這裏我建立的項目爲django1,初始目錄結構以下django
若是本身建立的項目不叫django1,則如下全部django1修改成本身的項目名。安全
編緝django1/django1/setting.py,定位到TEMPLATES變量,將DIRS的值修改成BASE_DIR+"/django1/templates",服務器
在django1/django1目錄下建立templates文件夾,並在其下建立get.html、post.html、result.html三個文件。框架
get.html,用於get提交:ide
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>get請求示例</title> </head> <body> <form action="/get" method="get"> <input type="text" name="q" /> <input type="submit" value="搜索" /> </form> </body> </html>
post.html,用於post提交。{%%}表示其內是Django模板語句,{% csrf_token %}指示此表單加載時返回token在其提交時進行token認證(若是要關閉服務端該csrf附御功能將setting.py----MIDDLEWARE----'django.middleware.csrf.CsrfViewMiddleware'註釋掉):post
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>post請求示例</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輸入的內容。{{}}表示其內是Django模板變量:url
<h1>{{ result }}</h1>
Django全部請求路由都由urls.py設置,即使是存在的靜態文件(如html)也要配置路由才能訪問。idea
編緝django1/django1/urls.py,修改成如下內容:spa
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.2中咱們配置了get.html、get、post.html、post四個請求分別轉交到view.get_html、view.get、view.post_html、view.post進行處理。本節咱們實現這四個處理邏輯。
在django1/django1文件夾下建立view.py,寫入如下內容:
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表單內容 # result爲重定向到的result.html所使用的變量 context['result'] = f"你搜索的內容爲:{request.GET['q']}" return render(request, 'result.html', context) def post_html(request): # 不能和get同樣使用render_to_response必須使用render進行重定向,否則服務端不會設置csrf_token # return render_to_response('post.html') return render(request, 'post.html') def post(request): context = {} # 經過request.GET['name']形式獲取post表單內容 # result爲重定向到的result.html所使用的變量 context['result'] = f"你搜索的內容爲:{request.POST['q']}" return render(request, 'result.html', context)
其中注意如註釋所強調,post_html中不能使用render_to_response必須使用render進行重定向,否則服務器不能成功返回token致使token驗證失敗進而致使不能訪問頁面(403,CSRF token missing or incorrect.)。以下圖所示:
另外,如上所示返回了詳細的錯誤信息,這在信息安全中是忌諱但這並非django沒考濾到,而是Django默認開啓DEBUG模式,到settings.py中設置DEBUG = False,並設置ALLOWED_HOSTS便可(ALLOWED_HOSTS不是指容許訪問服務的IP而是容許外部訪問服務地址)。
經第二大節全部操做,項目目錄結構以下圖所示(.idea和__pycache__不用管):
get請求頁面:
get請求結果:
post請求頁面:
post請求結果:
參考: