Web服務器開發領域裏著名的MVC模式,所謂MVC就是把Web應用分爲模型(M),控制器(C)和視圖(V)三層,他們之間以一種插件式的、鬆耦合的方式鏈接在一塊兒,模型負責業務對象與數據庫的映射(ORM),視圖負責與用戶的交互(頁面),控制器接受用戶的輸入調用模型和視圖完成用戶的請求,其示意圖以下所示:html
| M:models數據庫相關;V:views視圖相關 C:controller控制器 url分發 |前端
Django的MTV模式本質上和MVC是同樣的,也是爲了各組件間保持鬆耦合關係,只是定義上有些許不一樣,Django的MTV分別是值:python
除了以上三層以外,還須要一個URL分發器,它的做用是將一個個URL的頁面請求分發給不一樣的View處理,View再調用相應的Model和Template,MTV的響應模式以下所示:web
| M:models數據庫相關; T:templates模板 html文件 ;V:views視圖相關 + url分發 |正則表達式
通常是用戶經過瀏覽器向咱們的服務器發起一個請求(request),這個請求回去訪問視圖函數,(若是不涉及到數據調用,那麼這個時候視圖函數返回一個模板也就是一個網頁給用戶),視圖函數調用模型,模型去數據庫查找數據,而後逐級返回,視圖函數把返回的數據填充到模板中空格中,最後返回網頁給用戶。shell
Django官網下載頁面數據庫
pip3 install django==1.11.9
django-admin startproject first_project #建立了一個名爲"first_project"的Django 項目:
python manage.py runserver 127.0.0.1:8001 python manage.py runserver 8001 #本機就不用寫ip地址了 python manage.py runserver #若是連端口都沒寫,默認是本機的8000端口
這樣咱們的django就啓動起來了,只不過什麼邏輯也沒有呢!django
當咱們訪問:http://127.0.0.1:8080/時就能夠看到:瀏覽器
當前目錄下會生成first_project的工程,目錄結構以下:(你們注意昂,pip下載下來的django你就理解成一個模塊,而不是django項目,這個模塊能夠幫咱們建立django項目)服務器
python manage.py startapp app名稱 在settings中配置 'app01.apps.App01Config' 或者'app01'
1.file -->new project
2.Django -->項目名稱 -->選擇Python選擇器 -->應用名稱(業務邏輯相關的程序)
寫一個Django項目:
作一個登陸頁面的Web項目,瀏覽器輸入網址獲得一個web頁面 輸入網址:127.0.0.1:8000/login/ 1.建立項目 second_pro 2.建立app app02 3.urls.py from django.conf.urls import url from django.contrib import admin from app02 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^index/', views.index), ] 4.views.py 寫邏輯視圖 from django.shortcuts import render,HttpResponse # Create your views here. def index(request): # print(request.method) #獲取請求方式GET或POST if request.method=='GET': return render(request,'login.html') #回覆一個頁面 else: username=request.POST.get('username') #獲取post數據 password=request.POST.get('password') if username=='anwen' and password=='123': return HttpResponse('登陸成功!') #回覆字符串 else: return HttpResponse('登陸失敗!') 5.在templates文件夾中建立login.html 頁面 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>login</title> </head> <body> <form action="/index/" method="post"> <div> 用戶名:<input type="text" name="username"> </div> <div> 密碼: <input type="text" name="password"> </div> <input type="submit"> </form> </body> </html> 注意: 1.urls.py 裏面須要注意的問題: url(r'index/',views.index) #第一個參數路徑正則字符串,第二個參數對應的視圖邏輯 2. def index(request): # print(request.method) #獲取請求方式GET或POST request.GET ---GET請求發送來的全部數據,queryDict類型 request.POST ---POST請求發送來的全部數據,queryDict類型 request.GET.get('username') #獲取get數據 request.POST.get('username') #獲取post數據 return render(request,'login.html') #回覆一個頁面 return HttpResponse('登陸成功!') #回覆字符串
def index(request): print(retuest.GET) #<QueryDict:{'username':'anwen','password':['123']}> username=request.GET.get('username') password=request.GET.get('password') print(username,password) if username=='anwen' and password =='123': return HttpResponse('登陸成功') else: return HttpResponse('登陸失敗')
post請求提交數據時關掉一個認證機制,settings配置文件中
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', # 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
無名分組
url(r'^books/(\d{4})/',views.books) #(\d{4})
位置參數
url(r'^books/(\d{4})/',views.year_books) #匹配年份 url(r'^books/(\d{4})/(\d{1,2})/',views_year_month_books) #匹配年份和月份 #http://127.0.0.1:8000/books/2019/2/ 視圖: def year_month_books(request,year,month): #位置參數 ,第一個參數接收的是無名分組路徑中匹配到的第一個的分組數據,第二個參數接收到的就是無名分組中路徑中匹配到的第二個分組數據 print(year,month)
分組命名匹配
在Python的正則表達式中,分組命名正則表達式組的語法是(?P<name>pattern),其中name是組的名稱,pattern是要匹配的模式。使用命名組的重寫 url(r'^books/(?p<year>\d{4})/(?p<month>\d{1,2}/',views.year_month_books)#匹配年份和月份 def year_month)books(request,.month,year):#形參名稱要和url中的分組名稱對應,參數位置沒有順序要求 print(year,month)
默認值
#urls.py中 from django.conf.url import url from . import views urlpatterns=[ # 視圖函數中指定默認值,若是第一個模式匹配上了,year_books()函數將使用其默認參數num=「1」,若是第二個模式匹配,year_books()將使用正則表達式捕獲到的num值。 url(r'^books/$', views.year_books), url(r'^books/(?P<num>\d{4})', views.year_books), ] #views.py中 def pag(request,num='10'): pass
#是否開啓URL訪問地址後面不爲/跳轉至帶有/的路徑的配置項 APPEND_SLASH=True Django settings.py配置文件中默認沒有 APPEND_SLASH 這個參數,但 Django 默認這個參數爲 APPEND_SLASH = True。 其做用就是自動在網址結尾加'/'。其效果就是:咱們定義了urls.py: from django.conf.urls import url from app01 import views urlpatterns = [ url(r'^blog/$', views.blog), ] 訪問 http://www.example.com/blog 時,默認將網址自動轉換爲 http://www.example/com/blog/ 。 若是在settings.py中設置了 APPEND_SLASH=False,此時咱們再請求 http://www.example.com/blog 時就會提示找不到頁面。
#項目文件夾下的urls.py文件中的url寫法: from django.conf.urls import url,include from django.contrib import admin from app01 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), #首頁 url(r'^$', views.base), url(r'^app01/', include('app01.urls')), url(r'^app02/', include('app02.urls')), ] #app01下urls.py內容寫法 from django.conf.urls import url from django.contrib import admin from app01 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^$', views.app01base), url(r'^index/', views.index), ] #app02下urls.py內容寫法 from django.conf.urls import url from django.contrib import admin from app02 import views urlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^$', views.app02base), url(r'^home/', views.home), ]
咱們本身寫的url裏面的路徑有沒有可能會更改,若是路徑更改了,那麼咱們前端訪問這個路徑的標籤(a標籤,form表單等等)裏面的屬性值是否是也要本身手動去改啊,這樣咱們拓展起來就不方便了,你想是否是?尤爲是前端可能不是你寫的,那你是否是要進行部門溝通啊,想想怎麼辦?
在使用Django 項目時,一個常見的需求是得到URL的最終形式,以用於嵌入到生成的內容中(視圖中和顯示給用戶的URL等)或者用於處理服務器端的導航(重定向等)。
簡單來講就是能夠給咱們的URL匹配規則起個名字,一個URL匹配模式起一個名字。這樣咱們之後就不須要寫死URL代碼了,只須要經過名字來調用當前的URL。
舉個簡單的例子:
url(r'^home', views.home, name='home'), # 給個人url匹配模式起名(別名)爲 home,別名不須要改,路徑你就能夠隨便改了,別的地方使用這個路徑,就用別名來搞 url(r'^index/(\d*)', views.index, name='index'), # 給個人url匹配模式起名爲index
在模板裏面能夠這樣引用:
{% url 'home' %} #模板渲染的時候,被django解析成了這個名字對應的那個url,這個過程叫作反向解析
在views函數中能夠這樣引用:
from django.urls import reverse reverse("index", args=("2018", )) #帶參數的