欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

Python Django基礎(chǔ)二之URL路由系統(tǒng)

系統(tǒng) 1720 0

MVC和MTV框架

MVC

 Web服務(wù)器開發(fā)領(lǐng)域里著名的MVC模式,所謂MVC就是把Web應(yīng)用分為模型(M),控制器(C)和視圖(V)三層,他們之間以一種插件式的、松耦合的方式連接在一起,模型負(fù)責(zé)業(yè)務(wù)對(duì)象與數(shù)據(jù)庫的映射(ORM),視圖負(fù)責(zé)與用戶的交互(頁面),控制器接受用戶的輸入調(diào)用模型和視圖完成用戶的請(qǐng)求,其示意圖如下所示:

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第1張圖片

| M:models數(shù)據(jù)庫相關(guān);V:views視圖相關(guān) C:controller控制器 url分發(fā) |

MTV

Django的MTV模式本質(zhì)上和MVC是一樣的,也是為了各組件間保持松耦合關(guān)系,只是定義上有些許不同,Django的MTV分別是值:

  • M 代表模型(Model): 負(fù)責(zé)業(yè)務(wù)對(duì)象和數(shù)據(jù)庫的關(guān)系映射(ORM)。
  • T 代表模板 (Template):負(fù)責(zé)如何把頁面展示給用戶(html)。
  • V 代表視圖(View): 負(fù)責(zé)業(yè)務(wù)邏輯,并在適當(dāng)時(shí)候調(diào)用Model和Template。

除了以上三層之外,還需要一個(gè)URL分發(fā)器,它的作用是將一個(gè)個(gè)URL的頁面請(qǐng)求分發(fā)給不同的View處理,View再調(diào)用相應(yīng)的Model和Template,MTV的響應(yīng)模式如下所示:

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第2張圖片

| M:models數(shù)據(jù)庫相關(guān); T:templates模板 html文件 ;V:views視圖相關(guān) + url分發(fā) |

一般是用戶通過瀏覽器向我們的服務(wù)器發(fā)起一個(gè)請(qǐng)求(request),這個(gè)請(qǐng)求回去訪問視圖函數(shù),(如果不涉及到數(shù)據(jù)調(diào)用,那么這個(gè)時(shí)候視圖函數(shù)返回一個(gè)模板也就是一個(gè)網(wǎng)頁給用戶),視圖函數(shù)調(diào)用模型,模型去數(shù)據(jù)庫查找數(shù)據(jù),然后逐級(jí)返回,視圖函數(shù)把返回的數(shù)據(jù)填充到模板中空格中,最后返回網(wǎng)頁給用戶。

Django下載安裝

Django官網(wǎng)下載頁面

1、下載Django:

pip3 install django==1.11.9

2、創(chuàng)建一個(gè)django project

django-admin startproject first_project?? #創(chuàng)建了一個(gè)名為"first_project"的Django 項(xiàng)目:

3、啟動(dòng)django項(xiàng)目

            
python manage.py runserver 127.0.0.1:8001
python manage.py runserver 8001  #本機(jī)就不用寫ip地址了 
python manage.py runserver #如果連端口都沒寫,默認(rèn)是本機(jī)的8000端口
          

這樣我們的django就啟動(dòng)起來了,只不過什么邏輯也沒有呢!

當(dāng)我們?cè)L問:http://127.0.0.1:8080/時(shí)就可以看到:

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第3張圖片

? 當(dāng)前目錄下會(huì)生成first_project的工程,目錄結(jié)構(gòu)如下:(大家注意昂,pip下載下來的django你就理解成一個(gè)模塊,而不是django項(xiàng)目,這個(gè)模塊可以幫我們創(chuàng)建django項(xiàng)目)

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第4張圖片

  • manage.py ----- Django項(xiàng)目里面的工具,通過它可以調(diào)用django shell和數(shù)據(jù)庫,啟動(dòng)關(guān)閉項(xiàng)目與項(xiàng)目交互等,不管你將框架分了幾個(gè)文件,必然有一個(gè)啟動(dòng)文件,其實(shí)他們本身就是一個(gè)文件。
  • settings.py ---- 包含了項(xiàng)目的默認(rèn)設(shè)置,包括數(shù)據(jù)庫信息,調(diào)試標(biāo)志以及其他一些工作的變量。
  • urls.py ----- 負(fù)責(zé)把URL模式映射到應(yīng)用程序。
  • wsgi.py ---- runserver命令就使用wsgiref模塊做簡(jiǎn)單的web server,后面會(huì)看到renserver命令,所有與socket相關(guān)的內(nèi)容都在這個(gè)文件里面了,目前不需要關(guān)注它。

創(chuàng)建app

            
python manage.py startapp app名稱
在settings中配置
'app01.apps.App01Config'  或者'app01'
          

pycharm創(chuàng)建django項(xiàng)目

1.file -->new project

2.Django -->項(xiàng)目名稱 -->選擇Python選擇器 -->應(yīng)用名稱(業(yè)務(wù)邏輯相關(guān)的程序)

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第5張圖片

項(xiàng)目目錄結(jié)構(gòu):

Python Django基礎(chǔ)二之URL路由系統(tǒng)_第6張圖片

寫一個(gè)Django項(xiàng)目:

            
做一個(gè)登錄頁面的Web項(xiàng)目,瀏覽器輸入網(wǎng)址得到一個(gè)web頁面
輸入網(wǎng)址:127.0.0.1:8000/login/

1.創(chuàng)建項(xiàng)目 second_pro
2.創(chuàng)建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)  #獲取請(qǐng)求方式GET或POST
    if request.method=='GET':
      return render(request,'login.html') #回復(fù)一個(gè)頁面
    else:
      username=request.POST.get('username')  #獲取post數(shù)據(jù)
      password=request.POST.get('password')
      if username=='anwen' and password=='123':
        return HttpResponse('登錄成功!')  #回復(fù)字符串
      else:
        return HttpResponse('登錄失敗!')
      
5.在templates文件夾中創(chuàng)建login.html 頁面
  
  
  
    
            
            
              login
            
            
用戶名:
密碼:
注意: 1.urls.py 里面需要注意的問題: url(r'index/',views.index) #第一個(gè)參數(shù)路徑正則字符串,第二個(gè)參數(shù)對(duì)應(yīng)的視圖邏輯 2. def index(request): # print(request.method) #獲取請(qǐng)求方式GET或POST request.GET ---GET請(qǐng)求發(fā)送來的所有數(shù)據(jù),queryDict類型 request.POST ---POST請(qǐng)求發(fā)送來的所有數(shù)據(jù),queryDict類型 request.GET.get('username') #獲取get數(shù)據(jù) request.POST.get('username') #獲取post數(shù)據(jù) return render(request,'login.html') #回復(fù)一個(gè)頁面 return HttpResponse('登錄成功!') #回復(fù)字符串

get請(qǐng)求獲取數(shù)據(jù):

            
def index(request):
  print(retuest.GET) #
            
              
  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請(qǐng)求提交數(shù)據(jù)時(shí)關(guān)掉一個(gè)認(rèn)證機(jī)制,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配置

無名分組

            
url(r'^books/(\d{4})/',views.books)   #(\d{4})
          

位置參數(shù)

            
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): #位置參數(shù) ,第一個(gè)參數(shù)接收的是無名分組路徑中匹配到的第一個(gè)的分組數(shù)據(jù),第二個(gè)參數(shù)接收到的就是無名分組中路徑中匹配到的第二個(gè)分組數(shù)據(jù)
  print(year,month)
          

分組命名匹配

            
在Python的正則表達(dá)式中,分組命名正則表達(dá)式組的語法是(?P
            
              pattern),其中name是組的名稱,pattern是要匹配的模式。使用命名組的重寫
url(r'^books/(?p
              
                \d{4})/(?p
                
                  \d{1,2}/',views.year_month_books)#匹配年份和月份
def year_month)books(request,.month,year):#形參名稱要和url中的分組名稱對(duì)應(yīng),參數(shù)位置沒有順序要求
  print(year,month)
                
              
            
          

默認(rèn)值

            
#urls.py中
from django.conf.url import url
from . import views
urlpatterns=[
  # 視圖函數(shù)中指定默認(rèn)值,如果第一個(gè)模式匹配上了,year_books()函數(shù)將使用其默認(rèn)參數(shù)num=“1”,如果第二個(gè)模式匹配,year_books()將使用正則表達(dá)式捕獲到的num值。
  url(r'^books/$', views.year_books),
  url(r'^books/(?P
            
              \d{4})', views.year_books),
]

#views.py中
def pag(request,num='10'):
  pass
            
          

注意事項(xiàng)

  1. urlpatterns中的元素按照書寫順序從上往下逐一匹配正則表達(dá)式,一旦匹配成功則不再繼續(xù)。
  2. 若要從URL中捕獲一個(gè)值,只需要在它周圍放置一對(duì)圓括號(hào)(分組匹配)。
  3. 不需要添加一個(gè)前導(dǎo)的反斜杠(也就是寫在正則最前面的那個(gè)/),因?yàn)槊總€(gè)URL 都有。例如,應(yīng)該是^articles 而不是 ^/articles。
  4. 每個(gè)正則表達(dá)式前面的'r' 是可選的但是建議加上。^articles& 以什么結(jié)尾,以什么開頭,嚴(yán)格限制路徑

url末尾加'/'補(bǔ)充說明

            
#是否開啟URL訪問地址后面不為/跳轉(zhuǎn)至帶有/的路徑的配置項(xiàng)
APPEND_SLASH=True

Django settings.py配置文件中默認(rèn)沒有 APPEND_SLASH 這個(gè)參數(shù),但 Django 默認(rèn)這個(gè)參數(shù)為 APPEND_SLASH = True。 其作用就是自動(dòng)在網(wǎng)址結(jié)尾加'/'。其效果就是:我們定義了urls.py:
  from django.conf.urls import url
  from app01 import views

  urlpatterns = [
      url(r'^blog/$', views.blog),
  ]
  
訪問 http://www.example.com/blog 時(shí),默認(rèn)將網(wǎng)址自動(dòng)轉(zhuǎn)換為 http://www.example/com/blog/ 。

  如果在settings.py中設(shè)置了 APPEND_SLASH=False,此時(shí)我們?cè)僬?qǐng)求 http://www.example.com/blog 時(shí)就會(huì)提示找不到頁面。
          

url路由分發(fā)之include

            
#項(xiàng)目文件夾下的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內(nèi)容寫法
  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內(nèi)容寫法  
  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),
  ]
          

總結(jié)

以上所述是小編給大家介紹的Python Django基礎(chǔ)二之URL路由系統(tǒng) ,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 热久久精品在线 | 亚洲国产精品国自产电影 | 91最新在线视频 | 九九激情网 | 国产精品色 | 精品人妻无码一区二区三区手机板 | 午夜寂寞在线观看 | 国产最新网址 | 天天在线欧美精品免费看 | 欧美日韩一区二区在线 | 国产网站视频 | 亚洲9777精品毛A片久久久 | 欧美精品九九99久久在观看 | 日韩在线播放第一页 | 久久草在线视频 | 蜜桃五月天 | 波多野结衣三级在线 | 2022国产91精品久久久久久 | 开心深爱激情 | 天天操人人射 | 天天爽天天色 | 国产人妻互换一区二区水牛影视 | 97国产精品视频人人做人人爱 | 欧美激情精品久久久久 | 成人免费毛片网站 | 美女午夜影院 | 亚洲亚洲人成综合网络 | 色呦呦免费 | 日韩精品一区二区在线观看 | 另类小说综合 | 欧美一区二区黄色片 | 欧美99| www欧美 | 久久久精| 国产精品日本无码久久一 | 国产久 | 欧美一区二区三区成人精品 | 国产99久久精品一区二区 | 亚洲婷婷综合网 | 米奇7777狠狠狠狠视频 | 色视频在线观看 |