Django URLPattern 和 URLResolver 的区别详解

在 Django 中,URL 配置是项目的入口。我们经常会在 urls.py 中看到 path()include(),但很多初学者会搞混:

  • URLPattern 和 URLResolver 有什么区别?

  • 它们在 Django 的请求处理流程中扮演什么角色?

本文将详细拆解这两个核心对象,并配合实例帮助你彻底理解。


1. URLConf 是什么?

在 Django 项目中,ROOT_URLCONF 配置项指定了全局 URL 配置文件,一般是 project/urls.py

示例:

python 复制代码
# project/urls.py
from django.urls import path, include
from . import views

urlpatterns = [
    path("hello/", views.hello_view),           # URLPattern
    path("blog/", include("blog.urls")),        # URLResolver
]
  • urlpatterns 是一个 列表

  • 列表中可以包含 URLPatternURLResolver

  • Django 会递归匹配,直到找到最终的视图函数


2. URLPattern 是什么?

URLPattern 代表一个单一的路由规则,通常使用 path()re_path() 定义。

例如:

python 复制代码
path("hello/", views.hello_view)
  • URLhello/

  • 视图函数views.hello_view

  • 作用 :当请求路径匹配 hello/ 时,直接调用 hello_view 视图函数。

换句话说,URLPattern 就是一条最小的 URL 映射规则


3. URLResolver 是什么?

URLResolver 用于路由分发,通常通过 include() 引入子路由。

示例:

python 复制代码
# project/urls.py
path("blog/", include("blog.urls"))

blog/urls.py 中继续定义:

python 复制代码
# blog/urls.py
from django.urls import path
from . import views

urlpatterns = [
    path("list/", views.blog_list),
    path("detail/<int:id>/", views.blog_detail),
]

请求 /blog/list/ 时的执行过程:

  1. Django 在 project/urls.py 中找到匹配项 path("blog/", include("blog.urls"))

  2. 进入 blog/urls.py

  3. 匹配到 path("list/", views.blog_list)

  4. 执行视图函数 blog_list

这样就实现了 递归匹配


4. URLPattern vs URLResolver 对比图

python 复制代码
project/urls.py (ROOT_URLCONF)

│
├─ URLPattern: "hello/"  → views.hello_view
│
└─ URLResolver: "blog/" → include("blog.urls")
        │
        ├─ URLPattern: "list/"            → views.blog_list
        └─ URLPattern: "detail/<int:id>/" → views.blog_detail
  • URLPattern

    • 一对一映射

    • 匹配后直接执行视图函数

  • URLResolver

    • 递归分发

    • 匹配后进入子路由继续查找


5. 为什么要区分?

如果没有 URLResolver,那么所有路由规则都必须写在 project/urls.py,会导致文件非常庞大,不利于维护。

通过 URLResolver:

  • 可以把不同模块的路由拆分到子应用

  • 项目更清晰、可扩展性更强

  • 也更符合 Django 的 app 解耦思想


6. 总结

  1. URLPattern:最小的路由匹配单元,直接指向视图函数。

  2. URLResolver:路由分发器,用于包含子路由,实现递归匹配。

  3. Django 的路由匹配是递归的,直到找到一个具体的 URLPattern。

相关推荐
Q_Q51100828521 小时前
python+uniapp基于微信小程序的旅游信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js
Q_Q51100828521 小时前
python基于web的汽车班车车票管理系统/火车票预订系统/高铁预定系统 可在线选座
spring boot·python·django·flask·node.js·汽车·php
Q_Q5110082851 天前
python+django/flask婚纱摄影拍照管理系统
spring boot·python·django·flask·node.js·php
Q_Q5110082852 天前
python+uniapp基于微信小程序的心理咨询信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js
Q_Q5110082852 天前
python+uniapp基于微信小程序的学院设备报修系统
spring boot·python·微信小程序·django·flask·uni-app
liweiweili1262 天前
Django中处理多数据库场景
数据库·python·django
workflower3 天前
Fundamentals of Architectural Styles and patterns
开发语言·算法·django·bug·结对编程
局外人LZ3 天前
django rest framework:从零开始搭建RESTful API
python·django·restful·drf
weixin_421133414 天前
Django 的文档接口
python·django·sqlite
合作小小程序员小小店5 天前
web开发,学院培养计划系统,基于Python,FlaskWeb,Mysql数据库
后端·python·mysql·django·web app