加入收藏 | 设为首页 | 会员中心 | 我要投稿 北几岛 (https://www.beijidao.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

drf 自动生成接口文档

发布时间:2021-05-21 07:28:19 所属栏目:大数据 来源: https://www.jb51.cc
导读:coreapi 在 drf 中,能够支持我们自动生成 API 文档的模块有很多,这里使用的是 coreapi 。 pip install coreapi 切记一点, coreapi 生成的接口文档的接口只能是继承自 APIView 及其子类的视图接口。 基本使用 在线文档 由于生成的文档是在线的,所以我们需

coreapi

   在drf中,能够支持我们自动生成API文档的模块有很多,这里使用的是coreapi

pip install coreapi

   切记一点,coreapi生成的接口文档的接口只能是继承自APIView及其子类的视图接口。

基本使用

在线文档

   由于生成的文档是在线的,所以我们需要在主路由下进行配置。

from rest_framework.documentation import include_docs_urls

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

全局配置

   对djangorestframework进行配置,在全局项目文件夹下的settings.py中书写如下代码:

REST_FRAMEWORK = {
    # 'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.openapi.AutoSchema',# 这是默认的
    'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema',# 新版用这个
}

接口说明

   接口一般分为三种,每次定义好接口后使用三双引号或三单引号注释为其进行说明,当说明完成后将会自动进行文档生成。

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

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

    retrieve:
    返回图书详情数据

    latest:
    返回最新的图书数据

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

访问展示

   接下来访问http://127.0.0.1:8000/docs/你将会看到所有的接口以及描述:

  

image-20201104151550686

   需要注意的是,视图集ViewSet中的retrieve名称,在接口文档网站中叫做read

   另外,参数的Description需要在模型类或序列化器类的字段中以help_text选项定义,如:

class Student(models.Model):
    ...
    age = models.IntegerField(default=0,verbose_name='年龄',help_text='这是学生的年龄信息,默认是0')
    ...

   或者你也可以在序列化器中进行定义:

class StudentSerializer(serializers.ModelSerializer):
    class Meta:
        model = Student
        fields = "__all__"
        extra_kwargs = {
            'age': {
                'required': True,'help_text': '年龄'
            }
        }

(编辑:北几岛)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读