- Django从配置文件中根据
找到主路由文件,也就是我们的主目录下的ROOT_URLCONF
urls.py
- Django找到
中的urls.py
变量,该内容是一个包含多个路由的数组.urlpatterns
from django.contrib import admin
from django.urls import path
from . import views
# 项目的主路由配置-HTTP进入请求Django后,优先调用urls
urlpatterns = [
path('admin/', admin.site.urls),
path('apps/django/',views.apps_dijango),
]
复制
- 依次匹配
中的urlpatternes
path
- 匹配成功-调用对应函数视图
- 匹配失败-返回404
视图函数
视图函数是一个用来接收浏览器请求(HttpRequest)对象并通过
HttpRequest
对象返回响应函数。此函数可以接收浏览器请求并根据业务逻辑返回相应的内容.
语法
# 第一个参数必须为Request,其他参数可以依次向后写
def api_tools(request):
return HttpResponse
复制
路由配置
from django.urls import path
ali = {
path(route,views,name=None),
path(route2,views.page2)
}
参数;
1. route: 字符串类型,匹配请求路径
2. views: 指定路径对应视图处理函数的名称,需要与views匹配
3. name: 为地址起别名,在模板中地址反向解析时使用
复制
Path转换器
语法
<转换器类型:自定义名>
path('page/<int:page>',views.page)
# 以下是视图函数内容
def test(request,page_num):
return HttpResponse(page_num)
复制
作用:若转换器类型匹配到对应类型的数据,则将数据按照关键字传参的方式传递给视图函数。
转换器类型
-
:匹配除了str
之外的非空字符串/
/v1/api/<str:toolsname>
匹配
/v1/api/coretools
复制
-
: 匹配或任何整数,可以返回一个Intint
/v1/api/<int:page>
匹配
/v1/api/100
复制
-
: 匹配任意由ASCII字母或数字以及连字符和下划线组成的短标签slug
/v1/api/<slug:sl>
匹配
/v1/api/this-is-user_list
复制
-
:匹配非空字段,包括路径分隔符path
/
/v1/api/<path:ph>
匹配
/v1/api/a/b/c
复制
re_path
在url的匹配过程中可以使用正则表达式进行精确匹配
语法
from django.urls import re_path
re_path(reg,view,name=xxx)
# 正则表达式为命名分组模式(?P<name>pattern)匹配提取参数后用关键字传参方式传递给视图函数
复制