为了账号安全,请及时绑定邮箱和手机立即绑定

Django 2.x drf-yasg 如何在自定义方法中创建 API(如在 swagger 中)

Django 2.x drf-yasg 如何在自定义方法中创建 API(如在 swagger 中)

白衣非少年 2022-05-24 18:14:52
我正在将我的 Django 1.11.7 迁移到 2.x。问题之一是 django-rest-swagger,它现在已被弃用。现在 drf-yasg 应该是 API 文档和创建的方式。我需要以类似的方式创建自定义 api,因为它不会破坏移动设备中的任何内容。以前是这样的(django-rest-swagger==2.1.1)这是在 Django 1.11.7 和 django-rest-swagger==2.1.1 中运行良好的旧代码片段:using swagger_schema.pyhttps://gist.github.com/axilaris/2f72fef8f30c56d5befe9e31cd76eb50in url.py:from rest_framework_swagger.views import get_swagger_viewfrom myapp.swagger_schema import SwaggerSchemaViewurlpatterns = [     url(r'^swaggerdoc/', SwaggerSchemaView.as_view()),   url(r'^api/v1/general/get_countries$', api.get_countries, name='get_countries'),in api.py:@api_view(['POST'])def get_countries(request):    # ----- YAML below for Swagger -----    """    description: countries list    parameters:      - name: token        type: string        required: true        location: form       """    ......    return Response(countries_list, status=status.HTTP_200_OK)我的问题是如何在 drf-yasg 中进行类似的操作,因为我想迁移此代码并且不破坏移动设备上的任何内容。可能会尝试在这个最新的稳定版本上执行此操作:djangorestframework==3.9drf-yasg==1.16.1
查看完整描述

1 回答

?
慕码人8056858

TA贡献1803条经验 获得超6个赞

你可以在你的api.py. 这将生成您在屏幕截图中显示的内容:


from drf_yasg import openapi

from drf_yasg.utils import swagger_auto_schema


from rest_framework.decorators import api_view, parser_classes

from rest_framework.parsers import FormParser


token = openapi.Parameter('token', openapi.IN_FORM, type=openapi.TYPE_STRING, required=True)



@swagger_auto_schema(

    method="post",

    manual_parameters=[token]

)

@api_view(["POST"])

@parser_classes([FormParser])

def get_countries(request):

    """

    Countries list

    """

    ......

    return Response(countries_list, status=status.HTTP_200_OK)

请注意,我添加了@parser_classes([FormParser])装饰器以确保视图接受表单数据。如果您的所有端点仅使用表单数据并且您在 DRF 设置中全局设置它,您可以将其删除。


结果:

//img1.sycdn.imooc.com//628cb0460001dc3217910855.jpg

查看完整回答
反对 回复 2022-05-24
  • 1 回答
  • 0 关注
  • 256 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号