一.路由Routers
对于视图集ViewSet,我们除了可以自己手动指明请求方式与动作action之间的对应关系外,还可以使用Routers来帮助我们快速实现路由信息。
REST framework提供了两个router
- SimpleRouter
- DefaultRouter
1.1 使用方法
1) 创建router对象,并注册视图集,例如
from rest_framework import routers
router = routers.SimpleRouter() #实例化
router.register('books',views.BookViewSet)
SimpleRouter会产生两个路由:
<URLPattern '^books/$' [name='book-list']>,
<URLPattern '^books/(?P<pk>[^/.]+)/$'[name='book-detail']>
DefaultRouter会产生六个路由:
^books/$ [name='book-list']
^books/(?P<pk>[^/.]+)/$ [name='book-detail'] 这两条跟simple一样
^$ [name='api-root'] 根,根路径会显示出所有可以访问的地址
^.(?P<format>[a-z0-9]+)/?$ [name='api-root']
^books.(?P<format>[a-z0-9]+)/?$ [name='book-list'] http://127.0.0.1:8000/books.json
^books/(?P<pk>[^/.]+).(?P<format>[a-z0-9]+)/?$ [name='book-detail'] http://127.0.0.1:8000/books/1.json
2)把生成的路由列表追加到urlpatterns
urlpatterns += router.urls
1.2 action的使用
作用:给继承自ModelViewSet的视图类中定义的函数也添加路由
使用:
装饰器,放在被装饰的函数上方,method:请求方式,detail:是否带pk
class BookViewSet(ModelViewSet):
queryset =Book.objects.all()
serializer_class = BookSerializer
@action(methods=['GET','POST'],detail=True)
def get_1(self,request,pk):
print(pk)
book=self.get_queryset()[:2] # 从0开始截取一条
ser=self.get_serializer(book,many=True)
return Response(ser.data)
# methods第一个参数,传一个列表,列表中放请求方式,
# ^books/get_1/$ [name='book-get-1'] 当向这个地址发送get请求,会执行下面的函数
# detail:布尔类型 如果是True
#^books/(?P<pk>[^/.]+)/get_1/$ [name='book-get-1']