DRF路由

路由Routers

对于视图集ViewSet,我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用Routers来帮助我们快速实现路由信息。

REST framework提供了两个router

  • SimpleRouter
  • DefaultRouter

1. 使用方法

1) 创建router对象,并注册视图集,例如

from rest_framework import routers

router = routers.SimpleRouter()
router.register(r'books', BookInfoViewSet, base_name='book')

register(prefix, viewset, base_name)

  • prefix 该视图集的路由前缀
  • viewset 视图集
  • base_name 路由名称的前缀

如上述代码会形成的路由如下:

^books/$    name: book-list
^books/{pk}/$   name: book-detail

2)添加路由数据

可以有两种方式:

urlpatterns = [
    ...
]
urlpatterns += router.urls

urlpatterns = [
    ...
    url(r'^', include(router.urls))
]

2. 视图集中附加action的声明

在视图集中,如果想要让Router自动帮助我们为自定义的动作生成路由信息,需要使用rest_framework.decorators.action装饰器。

以action装饰器装饰的方法名会作为action动作名,与list、retrieve等同。

action装饰器可以接收两个参数:

  • methods: 声明该action对应的请求方式,列表传递
  • detail: 声明该action的路径是否与单一资源对应,及是否是xxx/<pk>/action方法名/
    • True 表示路径格式是xxx/<pk>/action方法名/
    • False 表示路径格式是xxx/action方法名/

举例:

from rest_framework import mixins
from rest_framework.viewsets import GenericViewSet
from rest_framework.decorators import action

class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
    queryset = BookInfo.objects.all()
    serializer_class = BookInfoSerializer

    # detail为False 表示路径名格式应该为 books/latest/
    @action(methods=['get'], detail=False)
    def latest(self, request):
        """
        返回最新的图书信息
        """
        ...

    # detail为True,表示路径名格式应该为 books/{pk}/read/
    @action(methods=['put'], detail=True)
    def read(self, request, pk):
        """
        修改图书的阅读量数据
        """
        ...

由路由器自动为此视图集自定义action方法形成的路由会是如下内容:

^books/latest/$    name: book-latest
^books/{pk}/read/$  name: book-read

3. 路由router形成URL的方式

1) SimpleRouter

2)DefaultRouter

DefaultRouter与SimpleRouter的区别是,DefaultRouter会多附带一个默认的API根视图,返回一个包含所有列表视图的超链接响应数据。

<think>嗯,用户想了解Django REST framework(DRF)中的路由对照表。好的,首先我需要回忆一下DRF路由机制。记得DRF提供了DefaultRouter和SimpleRouter这两个类来自动生成URL路由,这样可以简化视图集的URL配置。 首先,用户提到的“路由对照表”可能是指这些自动生成的路由规则。需要解释DefaultRouter和SimpleRouter的区别。DefaultRouter会生成包括API根视图和默认的格式后缀,而SimpleRouter更基础,没有那些额外的功能。然后,可能需要详细说明注册视图集的过程,比如使用router.register()方法,以及生成的路由URL模式。 然后,用户可能需要具体的例子来理解。比如,创建一个路由器实例,注册一个视图集,然后展示生成的URL路径。例如,对于UserViewSet,使用SimpleRouter可能会生成/users/和/users/{pk}/这两个路径,分别对应list和detail操作。 接下来,可能需要提到视图集中的动作(actions)如何映射到HTTP方法。例如,list对应GET,create对应POST,retrieve对应GET单个实例,update对应PUT,partial_update对应PATCH,destroy对应DELETE。此外,如果用户使用了自定义动作,比如用@action装饰器,那么这些动作也会生成额外的路由,比如/users/{pk}/activate/。 还需要说明不同的路由类生成的路由有何不同。比如DefaultRouter会多一个.api的后缀,以及根视图,而SimpleRouter则更简洁。此外,格式后缀的处理,比如.json是否启用,取决于include的参数。 另外,用户可能想知道如何自定义路由,比如修改URL路径中的前缀或查字段,或者调整映射关系。可能需要提到如何通过视图集的basename参数来覆盖默认的基名称,或者使用@action装饰器的参数来改变URL路径。 最后,总结一下使用DRF路由的好处,比如减少手动编写URL配置的工作量,保持一致性,以及便于维护。同时提醒用户如果遇到复杂需求,可能需要自定义路由或结合其他方法。 在组织回答的时候,要确保结构清晰,分点说明,可能用步骤式的方式解释注册和使用路由器的过程。同时要注意使用正确的中文术语,避免技术术语的混淆,必要时给出代码示例,但按照系统级指令,数学公式和代码可能需要用特定格式,不过这里主要是代码示例,可能不需要LaTeX,但需要正确展示。</think>在Django REST framework (DRF)中,路由对照表主要涉及如何将视图集(ViewSet)的`actions`映射到具体的URL路径。以下是逐步说明: --- ### **一、DRF路由核心机制** DRF通过`SimpleRouter`和`DefaultRouter`类自动生成路由,将视图集中的方法(如`list`, `create`等)与HTTP方法及URL路径匹配。 --- ### **二、路由对照表示例** 以`SimpleRouter`为例,注册视图集后生成的典型路由如下: ```python # 创建路由实例 from rest_framework.routers import SimpleRouter router = SimpleRouter() # 注册视图集 router.register('users', UserViewSet, basename='user') # 生成的路由对照表 urlpatterns = [ path('', include(router.urls)), ] ``` #### **生成的路由对照表** | URL路径 | HTTP方法 | 视图集方法 | 作用 | |------------------|----------|-------------|-------------------| | `/users/` | GET | `list` | 获取列表 | | `/users/` | POST | `create` | 创建新对象 | | `/users/{pk}/` | GET | `retrieve` | 获取单个对象 | | `/users/{pk}/` | PUT | `update` | 全量更新对象 | | `/users/{pk}/` | PATCH | `partial_update` | 部分更新对象 | | `/users/{pk}/` | DELETE | `destroy` | 删除对象 | --- ### **三、DefaultRouter vs SimpleRouter** | 特性 | SimpleRouter | DefaultRouter | |---------------------|----------------------------|---------------------------------| | API根视图 | ❌ 不生成 | ✅ 生成根视图(列出所有路由) | | 格式后缀(.json等) | ❌ 默认不启用 | ✅ 支持后缀如`.json`, `.api` | | 路由复杂性 | 更简单 | 包含额外功能 | --- ### **四、自定义路由行为** #### 1. 修改URL路径参数 ```python router.register(r'custom-users', UserViewSet, basename='user') # 路径变为 /custom-users/ ``` #### 2. 自定义`@action`扩展路由 在视图集中添加自定义方法: ```python class UserViewSet(ModelViewSet): @action(detail=True, methods=['post']) def activate(self, request, pk=None): # 自定义逻辑 pass ``` 生成路由: ``` /users/{pk}/activate/ → POST → activate() ``` #### 3. 修改URL查字段 通过`lookup_field`和`lookup_url_kwarg`: ```python class UserViewSet(ModelViewSet): lookup_field = 'uuid' # 模型字段 lookup_url_kwarg = 'id' # URL参数名 ``` 生成路径: ``` /users/{id}/ → 使用uuid字段查对象 ``` --- ### **五、核心优势** - **自动化映射**:减少手动编写URL配置的工作量 - **一致性**:统一RESTful接口风格 - **可扩展性**:通过`@action`轻松添加非标准操作 --- ### **六、注意事项** - 使用`basename`避免视图集命名冲突 - 复杂业务逻辑可能需要手动配置`urlpatterns` - 可通过`Router.urls`查看生成的所有路由 如果需要更深度定制,可继承`BaseRouter`类实现自定义路由逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值