Swagger的简介:
Swagger
是一个规范和完整的框架,用于生成、描述、调用和可视化RESTful
风格的Web
服务,在做后端开发的同时自动生成一个api文档供前端查看,当接口有变动时,对应的接口文档也会自动更新。
Swagger的优势:
Swagger生成一个API控制台,开发者可快速管理和获取API接口信息
Swagger的部署步骤:
Swagger的依赖:
django-rest-framework,换言之在前后端分离开发的时候,swagger是和drf配合使用的。
Swagger的安装:
pip install django-rest-swagger
Swagger在settings.py中的配置:
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'rest_framework',
'rest_framework_swagger', # swagger自动生成接口文档
]
Swagger在项目主路由urls.py中的配置:
from django.urls import path
# 导入restframework的辅助函数get_schema_view,获取架构视图
from rest_framework.schemas import get_schema_view
# 导入swagger的两个Render类
from rest_framework_swagger.renderers import SwaggerUIRenderer,OpenAPIRenderer
# 利用get_schema_view()方法,传入两个Render类得到一个schema view
schema_view = get_schema_view(title='API',renderer_classes=[SwaggerUIRenderer,OpenAPIRenderer])
# 配置接口文档的访问路径
urlpatterns = [
path('docs/', schema_view, name="swagger")
]
Swagger接口说明:
Swagger测试:
python manage.py runserver 启动服务,浏览器访问localhost:8001/docs/或者http://127.0.0.1:8001/docs/
。8001为端口,实际测试中以自己的端口为准。
Swagger错误处理:
错误1:'AutoSchema' object has no attribute 'get_link'
解决:REST_FRAMEWORK中添加'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema', # rest_framework_swagger的配置
REST_FRAMEWORK = {
'DEFAULT_SCHEMA_CLASS': 'rest_framework.schemas.coreapi.AutoSchema', # rest_framework_swagger的配置}
错误2:'staticfiles' is not a registered tag library. Must be one of:
解决:找到虚拟环境文件夹env/lib/python3.10/site-packages/rest_framework_swagger/templates/rest_framework_swagger/index.html,将第二行的{% load staticfiles %} 修改为:{% load static %}
刷新浏览器,重新测试。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。