URL格式:
protocol://hostname[:port]/path[?query][#fragment]
protocol:http非加密模式、https加密模式和file本地文件模式。
hostname:域名(IP)。
port:端口地址,默认80端口。
path:路由地址,代表详细地址,不包含host。
query:常以问号开头,以键值对的形式出现,代表查询的参数。
fragement:锚点,信息片段,以#开头,作用也是辅助定位。
Django处理请求的一般步骤:
- 针对请求地址从项目配置文件settings.py中找到ROOT_URLCONF对应的主路由位置,即找到urls.py文件。
- Django加载主路由文件中的urlpatterns中对应的路由地址,列表形式进行索引。
- 一旦找到即可跳转不会继续往下索引,找不到返回404错误,根据path中地址跳转到视图函数。
此处创立视图函数用来处理请求,方便网页跳转。在同目录文件夹中创建views.py视图文件。注意此时路由中引入views.py采用相对路径即:
from . import views
此时views.py文件中需要导入响应相关包:
该文件自定义函数响应时,默认request参数必须存在,若使用path转换器时则必须添加新的形参,即path转换器中的形参变量。
from django.http import HttpResponse
views.py文件:
路由urls.py中的path配置:若是写主页则route为空,其他正常即可。
语法:path(route,views,name=None
route:字符串类型,即匹配的请求地址。不含host和最后的“/".
views:route路径对应的跳转函数名称,views.xxx
name:为地址起别名,在模板地址反向解析时可能会用到。
路由文件urls.py:
path转换器:
若转换器类型匹配到对应类型的数据,则按照关键字传参的方式传给视图函数,views.py,只匹配关键部分,其他部分照写。
语法:<转换器类型:自定义名>
转换器类型:
str,匹配除“/“外的非空字符。
int,匹配0或任何整数,返回仍是int型。
slug,匹配任意由ASCII字母或者数字和连字符、下划线组成的短标签。
path,匹配非空字段,包括”/”。
下图是简易乘法计算器功能,urls.py和views.py文件。
re_path() 正则转换器:
语法:re_path(reg,view,name=xxx)
reg正则表达形式与爬虫一致,(?Ppattern)。
匹配提取参数后使用关键字传参的方式传给视图。前面的r需要,^和$是为了精确匹配。
例如1-2位加法器的使用:
re_path(r'^(?P<x>\d{1,2})/(?P<add>\w+/(?P<x>\d{1,2})$')
正则语法:菜鸟教程
https://www.runoob.com/regexp/regexp-syntax.html