如何在 Django ReDoc 中添加 PHP 和 C# 的请求示例
How to add Request Samples of PHP and C# in Django ReDoc
我正在为我的 Django Rest API 文档使用 drf-yasg 包。
默认情况下,它只显示一个名为 "Payload" 的请求示例,如下所示 link。
https://i.stack.imgur.com/1Pno2.jpg
我想添加更多请求示例,如下图所示。
https://i.stack.imgur.com/yy9tv.png
如果重写方法 get_operation from SwaggerAutoSchema class.[=14= 就可以添加它]
from drf_yasg.inspectors import SwaggerAutoSchema
class CustomAutoSchema(SwaggerAutoSchema):
def get_operation(self, operation_keys=None):
operation_keys = operation_keys or self.operation_keys
consumes = self.get_consumes()
produces = self.get_produces()
body = self.get_request_body_parameters(consumes)
query = self.get_query_parameters()
parameters = body + query
parameters = filter_none(parameters)
parameters = self.add_manual_parameters(parameters)
operation_id = self.get_operation_id(operation_keys)
summary, description = self.get_summary_and_description()
security = self.get_security()
assert security is None or isinstance(security, list), "security must be a list of security requirement objects"
deprecated = self.is_deprecated()
tags = self.get_tags(operation_keys)
responses = self.get_responses()
return openapi.Operation(
operation_id=operation_id,
description=force_real_str(description),
summary=force_real_str(summary),
responses=responses,
parameters=parameters,
consumes=consumes,
produces=produces,
tags=tags,
security=security,
deprecated=deprecated,
**{'x-code-samples': self.overrides.get('code_examples')}
)
然后您可以在您的视图中使用此模式
class MyViewSet(viewsets.ModelViewSet):
swagger_schema = CustomAutoSchema
并为您的视图方法添加装饰器:
@swagger_auto_schema(
code_examples=[
{
'lang': 'bash',
'source': 'curl -H "Authorization: Token YOUR-API-KEY" https://developers.typless.com/api/document-types/'
},
]
)
您可以在 this blog.
上阅读更多内容
我正在为我的 Django Rest API 文档使用 drf-yasg 包。 默认情况下,它只显示一个名为 "Payload" 的请求示例,如下所示 link。 https://i.stack.imgur.com/1Pno2.jpg 我想添加更多请求示例,如下图所示。 https://i.stack.imgur.com/yy9tv.png
如果重写方法 get_operation from SwaggerAutoSchema class.[=14= 就可以添加它]
from drf_yasg.inspectors import SwaggerAutoSchema
class CustomAutoSchema(SwaggerAutoSchema):
def get_operation(self, operation_keys=None):
operation_keys = operation_keys or self.operation_keys
consumes = self.get_consumes()
produces = self.get_produces()
body = self.get_request_body_parameters(consumes)
query = self.get_query_parameters()
parameters = body + query
parameters = filter_none(parameters)
parameters = self.add_manual_parameters(parameters)
operation_id = self.get_operation_id(operation_keys)
summary, description = self.get_summary_and_description()
security = self.get_security()
assert security is None or isinstance(security, list), "security must be a list of security requirement objects"
deprecated = self.is_deprecated()
tags = self.get_tags(operation_keys)
responses = self.get_responses()
return openapi.Operation(
operation_id=operation_id,
description=force_real_str(description),
summary=force_real_str(summary),
responses=responses,
parameters=parameters,
consumes=consumes,
produces=produces,
tags=tags,
security=security,
deprecated=deprecated,
**{'x-code-samples': self.overrides.get('code_examples')}
)
然后您可以在您的视图中使用此模式
class MyViewSet(viewsets.ModelViewSet):
swagger_schema = CustomAutoSchema
并为您的视图方法添加装饰器:
@swagger_auto_schema(
code_examples=[
{
'lang': 'bash',
'source': 'curl -H "Authorization: Token YOUR-API-KEY" https://developers.typless.com/api/document-types/'
},
]
)
您可以在 this blog.
上阅读更多内容