我正在使用drf-spectacular为django生成一个OpenAPI模式。因为我没有使用序列化器,所以我在extend_schema
装饰器中定义了所有内容。现在我的问题是,是否可以手动定义组件模式。
下面是我的API视图的一个例子:
from rest_framework.decorators import api_view
from drf_spectacular.utils import (extend_schema, OpenApiExample)
from drf_spectacular.types import OpenApiTypes
from rest_framework.response import Response
@extend_schema(
examples=[OpenApiExample(
value=[
{'title': 'A title'},
{'title': 'Another title'},
],
)],
responses={
200: OpenApiTypes.OBJECT
}
)
@api_view(['GET'])
def list_articles(request):
return Response([{'title': 'Test1'}, {'title': 'Test2'}])
并且相应的组件被示出为空(例如, Swagger ):
Here是文档中的定义,但我不知道如何使用drf-spectacular实现它。
2条答案
按热度按时间5lhxktic1#
OpenApiTypes.OBJECT
表示响应对象可以有任意数量的字段。当然,Swagger UI无法提前知道这些字段,因此它显示{}
,这可能不直观,但它是正确的。你想要的是给予你的回答一些结构。Spectacular中的一切都围绕着序列化器/组件。如果不想使用显式序列化程序,可以使用inline_serializer创建隐式序列化程序
gz5pxeao2#
也可以使用简单的字典代替
inline_serializer
: