当前位置:首页 > 科技  > 软件

简聊Fastapi框架中的OpenAPI规范

来源: 责编: 时间:2024-01-02 17:28:40 406观看
导读OpenAPI规范(也称为Swagger规范),在Fastapi框架中它主要用来定义和文档化API接口。关于OpenAPI规范是一种用于描述和定义Web API的标准化规范。它可以使用JSON或YAML等格式来描述API的各种元数据信息等细节,如接口路径、

OpenAPI规范(也称为Swagger规范),在Fastapi框架中它主要用来定义和文档化API接口。FEm28资讯网——每日最新资讯28at.com

关于OpenAPI规范是一种用于描述和定义Web API的标准化规范。它可以使用JSON或YAML等格式来描述API的各种元数据信息等细节,如接口路径、请求方法、请求和响应的数据结构、参数、错误处理等。FEm28资讯网——每日最新资讯28at.com

通过使用OpenAPI规范,我们可以轻松地生成API文档,并且可以使用各种工具来自动生成客户端代码、进行接口测试等。如Swagger UI,项目启动后就可以查看到具体的路由定义信息,并可以进行调试等。FEm28资讯网——每日最新资讯28at.com

FEm28资讯网——每日最新资讯28at.com

在整个框架应用中主要表现为:我们可以通过使用装饰器和Python类型提示来定义API接口相关信息。框架本身会根据我们定义的一些相关规则信息自动生成OpenAPI文档,并提供一个交互式的API文档页面,可以在其中查看和测试API接口。 这个文档页面基于Swagger UI,它可以根据OpenAPI规范自动生成,并提供了一些方便的功能,比如请求参数的验证和自动生成请求示例等。FEm28资讯网——每日最新资讯28at.com

应用主要场景:

我们可以使用OpenAPI规范来定义接口的各种细节,其中可以包括请求和响应的数据结构、参数、错误处理等信息。这样可以使得我们的API接口更加清晰、易于理解和使用。FEm28资讯网——每日最新资讯28at.com

1.定义应用app对象的元数据

pythonfrom fastapi import FastAPIapp = FastAPI(title="项目标题I", description="项目文档描述", version="1.0.0")

在上面的代码中,主要是通过参数定义为我应用示例对应的以及相关API元数据,例如标题、描述和版本号。FEm28资讯网——每日最新资讯28at.com

2.定义路由的元数据

@app.get("/items/{item_id}", summary="路由标题", description="路由描述说明")def get_item(item_id: int):    return {"item_id": item_id}

在上面的代码中,主要是通过装饰器参数为路由添加元数据,例如摘要和描述信息。 当然还有其他的参数可以传入。FEm28资讯网——每日最新资讯28at.com

3.定义模型的元数据

from pydantic import BaseModelclass Item(BaseModel):    name: str    description: str = Field(..., description="描述信息")

OpenAPI 自定义和扩展

1.示例

在fastapi框架提供了一个openapi的自定义参数,如下代码所示:FEm28资讯网——每日最新资讯28at.com

app.openapi = custom_openapi

基于上面的openapi我就可有针对进行扩展和自定义其他扩展字段信息,如下示例代码:FEm28资讯网——每日最新资讯28at.com

def custom_openapi():    if app.openapi_schema:        return app.openapi_schema    openapi_schema = get_openapi(        title="FastAPIBoilerplate",        version="0.0.1",        summary="FastAPIBoilerplate",        description='框架模板',        routes=app.routes,    )    openapi_schema["info"]["x-logo"] = {        "url": "https:xxxxxxxx"    }    app.openapi_schema = openapi_schema    return app.openapi_schema

如上代码中:我们通过获取app实例对象中已自动生成的 OpenAPI 规范后,在它毒药的 info 对象中添加一个 x-custom 字段。这个字段可以是任何 JSON 兼容的数据,例如字符串、数字、布尔值、列表或字典。如此完成后,当我们访问:FEm28资讯网——每日最新资讯28at.com

http://127.0.0.1:31120/openapi.json

即可获取到如下图所示的结果:FEm28资讯网——每日最新资讯28at.com

FEm28资讯网——每日最新资讯28at.com

当然我们还可以扩展其他的参数项: 如下代码所示:FEm28资讯网——每日最新资讯28at.com

 openapi_schema["info"]["x-custom"] = "自定义数据信息"

2.自定义和扩展作用和说明

一般通过在 OpenAPI 规范中添加额外的、非标准的信息一般可以用于:FEm28资讯网——每日最新资讯28at.com

  • 提供额外的文档信息。
  • 集成其他工具参数信息。
  • 包含额外的元数据。如 API 的版本历史、贡献者列表、相关资源的链接等。

本文链接:http://www.28at.com/showinfo-26-56428-0.html简聊Fastapi框架中的OpenAPI规范

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 面试官:说说JVM内存整体结构?线程私有还是共享的?

下一篇: 老生常谈 C# 开发 Windows 消息循环机制的原理和流程

标签:
  • 热门焦点
  • JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 分布式系统中的CAP理论,面试必问,你理解了嘛?

    对于刚刚接触分布式系统的小伙伴们来说,一提起分布式系统,就感觉高大上,深不可测。而且看了很多书和视频还是一脸懵逼。这篇文章主要使用大白话的方式,带你理解一下分布式系统
  • 十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • JavaScript学习 -AES加密算法

    引言在当今数字化时代,前端应用程序扮演着重要角色,用户的敏感数据经常在前端进行加密和解密操作。然而,这样的操作在网络传输和存储中可能会受到恶意攻击的威胁。为了确保数据
  • 华为发布HarmonyOS 4:更好玩、更流畅、更安全

    在8月4日的华为开发者大会2023(HDC.Together)大会上,HarmonyOS 4正式发布。自2019年发布以来,HarmonyOS一直以用户为中心,经历四年多的发展HarmonyOS已
  • 引领旗舰级影像能力向中端机普及 OPPO K11 系列发布 1799 元起

    7月25日,OPPO正式发布K系列新品—— OPPO K11 。此次 K11 在中端手机市场长期被忽视的影像板块发力,突破性地搭载索尼 IMX890 旗舰大底主摄,支持 OIS
  • Counterpoint :OPPO双旗舰战略全面落地 高端产品销量增长22%

    2023年6月30日,全球行业分析机构Counterpoint Research发布的《中国智能手机高端市场白皮书》显示,中国智能手机品牌正在寻求高质量发展,中国高端智能
  • 亲历马斯克血洗Twitter,硅谷的苦日子在后头

    文/刘哲铭  编辑/李薇  马斯克再次挥下裁员大刀。  美国时间11月14日,Twitter约4400名外包员工遭解雇,此次被解雇的员工的主要工作为内容审核等。此前,T
  • 北京:科技教育体验基地开始登记

      北京“科技馆之城”科技教育体验基地登记和认证工作日前启动。首批北京科技教育体验基地拟于2023年全国科普日期间挂牌,后续还将开展常态化登记。  北京科技教育体验基
Top