一、url是什么击奶?
??URL(Uniform Resoure Locator)統(tǒng)一資源定位符是對可以從互聯(lián)網(wǎng)上得到的資源的位置和訪問方法的一種簡潔的表示匹耕,是互聯(lián)網(wǎng)上標準資源的地址∨停互聯(lián)網(wǎng)上的每個文件都有一個唯一的URL忧额,它包含的信息指出文件的位置以及瀏覽器應(yīng)該怎么處理它。
??它最初是由蒂姆·伯納斯·李發(fā)明用來作為萬維網(wǎng)的地址±⒖冢現(xiàn)在它已經(jīng)被萬維網(wǎng)聯(lián)盟編制為互聯(lián)網(wǎng)標準RFC1738了睦番。
URL格式:schema://host[:port#]/path/.../[?query-string][#anchor]
- schema:指定使用的協(xié)議(例如:http, https, ftp)
- host:Http服務(wù)器的IP地址或者域名
- port:端口號,http默認是80端口
- path:訪問資源的路徑
- query-string:發(fā)送給http服務(wù)器的數(shù)據(jù)
- anchor:錨點
二耍属、Urls.py的作用
??URL配置(URLconf)就像是Django所支撐網(wǎng)站的目錄托嚣。它的本質(zhì)是URL模式以及要為該URL模式調(diào)用的視圖函數(shù)之間的映射表。以這樣的方式告訴Django厚骗,對于這個URL調(diào)用這段代碼示启,對于那個URL調(diào)用那段代碼。url的加載就是從配置文件中開始领舰。
Django會從urlpatterns里順次讀取元素夫嗓,每個元素是方法url調(diào)用后返回的結(jié)果。
??django傳給url路由要處理的地址冲秽,該地址是被去掉主機地址及之后的一個“/”的剩余部分:
??例如: http://127.0.0.1:8000/hello/
??經(jīng)處理后的剩余部分就是:
??hello/
??然后把該剩余部分與url方法的第一個參數(shù)進行正則匹配舍咖,如何匹配成功,則執(zhí)行url的第二個參數(shù)指定的方法(該方法一般放在views.py中锉桑,主要功能的實現(xiàn)具體業(yè)務(wù)邏輯)排霉。
url.py格式
Def url(regex, view, kwargs=None, name=None)
Regex: 傳入的url要匹配的正則表達式
View:一個可調(diào)用的對象或一個url類型的列表或元組
Kwargs:關(guān)鍵字參數(shù),必須是一個字典數(shù)組民轴,可以通過這個參數(shù)傳遞更多的信息給view
Name:關(guān)鍵字參數(shù)攻柠,是一個字符串球订,用于給regex匹配的字符串取名字
三、url.py運用實例
運行環(huán)境Ubuntu
step1 創(chuàng)建目錄并修改settings.py文件
django-admin.py startproject urlshow #創(chuàng)建urlshowdjango項目
cd urlshow #進入目錄中
python manage.py startapp books #創(chuàng)建app
tree #查看目錄結(jié)構(gòu)
vim urlshow/settings.py #修改setting.py文件
#在settings.py中添加'books' app
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'books'
]
step2 編寫url.py文件
vim urlshow/urls.py #編輯 urls.py文件
from django.conf.urls import url
from django.contrib import admin
from books import views #引入books中的views文件
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^hello/$',views.hello),
#當輸入以hello為開頭瑰钮,并以hello/結(jié)尾的路徑時冒滩,跳轉(zhuǎn)到views.py中hello方法中
url(r'^books/([\S\s]*)/$', views.hello_books)
#這里使用了正則表達式([/S/s]*)意為獲取路徑books/asd 后輸入的字符,只要路徑為前面所描述的如此,則跳轉(zhuǎn)到views中的hello_books方法中
]
^ 表示以什么什么開頭
$ 表示以什么什么結(jié)尾
^ $聯(lián)合使用表示必須完整匹配
注意:末尾的/是必須的浪谴,雖然瀏覽器會根據(jù)情況幫助自動添加/旦部,但是不要以為不輸入就等于不添加。
字符 | 描述 |
---|---|
\s | 匹配任何空白字符较店,包括空格士八、制表符、換頁符等等梁呈。等價于 [ \f\n\r\t\v]婚度。 |
\S | 匹配任何非空白字符。等價于 [^ \f\n\r\t\v]官卡。 |
正則規(guī)則
字符 | 描述 |
---|---|
\s | 匹配任何空白字符蝗茁,包括空格、制表符寻咒、換頁符等等哮翘。等價于 [ \f\n\r\t\v]。 |
\S | 匹配任何非空白字符毛秘。等價于 [^ \f\n\r\t\v]饭寺。 |
step3 編寫books/views.py文件
vim books/views.py #編輯views.py文件
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.http import HttpResponse
# Create your views here.
def hello(request):
return HttpResponse("Hello World")
def hello_books(request,hb): #這里另一個參數(shù)是urls.py中正則傳遞一串字符串
return HttpResponse("Hello"+hb)
step4 運行程序
python manage.py runserver
如看到如下則表示運行成功
step5 查看成果
打開瀏覽器 在地址欄寫上
http://127.0.0.1:8000/hello
http://127.0.0.1:8000/books/php
http://127.0.0.1:8000/books/django
如果效果如下圖則表示成功
參數(shù)傳遞示例
url(r‘books/\d{2}/$', views.books)
# books/66
url(r‘books/(?P<id>\d{2})/$', views.books)
#books/10 books(req,id=10)
url(r‘books/(?P<id>\d{2})/(?P<ver>\w+) /$', views.books)
#test/20/3 books(req,id=20,ver=3)
這里提供的一些方法也可以嘗試一下,基本與上差不多