一、url是什么?
URL(Uniform Resoure Locator)统一资源定位符是对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。互联网上的每个文件都有一个唯一的URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。
它最初是由蒂姆·伯纳斯·李发明用来作为万维网的地址。现在它已经被万维网联盟编制为互联网标准RFC1738了。
URL格式:schema://host[:port#]/path/.../[?query-string][#anchor]
- schema:指定使用的协议(例如:http, https, ftp)
- host:Http服务器的IP地址或者域名
- port:端口号,http默认是80端口
- path:访问资源的路径
- query-string:发送给http服务器的数据
- anchor:锚点
二、Urls.py的作用
URL配置(URLconf)就像是Django所支撑网站的目录。它的本质是URL模式以及要为该URL模式调用的视图函数之间的映射表。以这样的方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码。url的加载就是从配置文件中开始。
Django会从urlpatterns里顺次读取元素,每个元素是方法url调用后返回的结果。
django传给url路由要处理的地址,该地址是被去掉主机地址及之后的一个“/”的剩余部分:
例如: http://127.0.0.1:8000/hello/
经处理后的剩余部分就是:
hello/
然后把该剩余部分与url方法的第一个参数进行正则匹配,如何匹配成功,则执行url的第二个参数指定的方法(该方法一般放在views.py中,主要功能的实现具体业务逻辑)。
url.py格式
Def url(regex, view, kwargs=None, name=None)
Regex: 传入的url要匹配的正则表达式
View:一个可调用的对象或一个url类型的列表或元组
Kwargs:关键字参数,必须是一个字典数组,可以通过这个参数传递更多的信息给view
Name:关键字参数,是一个字符串,用于给regex匹配的字符串取名字
三、url.py运用实例
运行环境Ubuntu
step1 创建目录并修改settings.py文件
django-admin.py startproject urlshow #创建urlshowdjango项目
cd urlshow #进入目录中
python manage.py startapp books #创建app
tree #查看目录结构
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/结尾的路径时,跳转到views.py中hello方法中
url(r'^books/([\S\s]*)/$', views.hello_books)
#这里使用了正则表达式([/S/s]*)意为获取路径books/asd 后输入的字符,只要路径为前面所描述的如此,则跳转到views中的hello_books方法中
]
^ 表示以什么什么开头
$ 表示以什么什么结尾
^ $联合使用表示必须完整匹配
注意:末尾的/是必须的,虽然浏览器会根据情况帮助自动添加/,但是不要以为不输入就等于不添加。
字符 | 描述 |
---|---|
\s | 匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。 |
\S | 匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。 |
正则规则
字符 | 描述 |
---|---|
\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): #这里另一个参数是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
如果效果如下图则表示成功
参数传递示例
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)
这里提供的一些方法也可以尝试一下,基本与上差不多