drf -- 自动生成接口文档

官方文档:http://core-api.github.io/python-client/

  • REST framework可以自动帮助我们生成接口文档。

  • 接口文档以网页的方式呈现。

  • 自动接口文档能生成的是继承自APIView及其子类的视图。

安装依赖

  • REST framewrok生成接口文档需要coreapi库的支持。
  • 安装: pip install coreapi

设置接口文档访问路径

1.在配置文件settings.py中配置接口文档

REST_FRAMEWORK = {
    # 。。。 其他选项
    # 接口文档
    'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.AutoSchema',
}

2.在总路由中添加接口文档路径。

#参数`title`为接口文档网站的标题。
from rest_framework.documentation import include_docs_urls

​urlpatterns = [    ...    
          path('docs/', include_docs_urls(title='站点页面标题'))
]

3.文档描述说明的定义位置

  • 单一方法的视图,可直接使用类视图的文档字符串,如
class BookListView(generics.ListAPIView):
    """
    返回所有图书信息.
    """
  • 包含多个方法的视图,在类视图的文档字符串中,分开方法定义,如:
class BookListCreateView(generics.ListCreateAPIView):
    """
    get:
    返回所有图书信息.

    post:
    新建图书.
    """
  • 对于视图集ViewSet,仍在类视图的文档字符串中封开定义,但是应使用action名称区分,如
class BookInfoViewSet(mixins.ListModelMixin, mixins.RetrieveModelMixin, GenericViewSet):
    """
    list:
    返回图书列表数据

    retrieve:
    返回图书详情数据

    latest:
    返回最新的图书数据

    read:
    修改图书的阅读量
    """

访问接口文档网页

两点说明

  • 视图集ViewSet中的retrieve名称,在接口文档网站中叫做read
  • 参数的Description需要在模型类或序列化器类的字段中以help_text选项定义,如:
#方式一:
class Student(models.Model):
    ...
    age = models.IntegerField(default=0, verbose_name='年龄', help_text='年龄')
    ...

#方式二:
class StudentSerializer(serializers.ModelSerializer):
    class Meta:
        model = Student
        fields = "__all__"
        extra_kwargs = {
            'age': {
                'required': True,
                'help_text': '年龄'
            }
        }
posted @   志强爱璇璇  阅读(75)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示