【Python】一文带你认识 Web 框架之 FastAPI

简介: FastAPI是一个现代、快速(高性能)的Web框架,用于构建API,基于Python 3.6+,并使用了标准的Python类型注解(Python 3.5也支持类型注解),以获得交互式API文档(通过OpenAPI/Swagger)和自动验证。FastAPI是一个Web框架,它与Flask和Django等框架不同。它具有更高的性能和易用性,并提供了最新的标准和技术,例如类型注释、异步编程、请求和响应体(JSON和其他数据格式)的内置验证和文档生成等。

image.png
一、简介
FastAPI是一个现代、快速(高性能)的Web框架,用于构建API,基于Python 3.6+,并使用了标准的Python类型注解(Python 3.5也支持类型注解),以获得交互式API文档(通过OpenAPI/Swagger)和自动验证。 FastAPI是一个Web框架,它与Flask和Django等框架不同。它具有更高的性能和易用性,并提供了最新的标准和技术,例如类型注释、异步编程、请求和响应体(JSON和其他数据格式)的内置验证和文档生成等。

    FastAPI的目标是帮助构建更好的API,尽可能简单而快速,并使API更容易创建和部署。它的设计重点在于提高开发人员的生产力并保持代码清晰和易于理解。这使得FastAPI成为构建精细和高性能API的理想选择。FastAPI的强大功能使得它成为许多Python开发人员的首选框架。

二、发展史
FastAPI于2019年发布。它是由Sebastian Ramirez创建的,他曾经为12个国家的公司工作,包括伊利诺伊州大学(University of Illinois),Cloudinary,gumgum Inc等等。他还是Pydantic框架的创建者,并成为了多个开源项目的贡献者,例如拖动PDF的pdfkit和 PDFTables等。他是Python开发人员社区活跃分子和会议演讲人,并在Python开发人员社区拥有广泛的联系。

    FastAPI于2019年首次推出,其设计初衷是为了解决Python Web框架在数据类型验证和文档生成方面的问题。与Flask等传统Web框架不同,FastAPI使用了Python类型注解和Pydantic模型,并使用async/await异步语法以提高性能。 FastAPI还支持使用OpenAPI和Swagger进行文档生成,使API整个生命周期更易于管理。

    FastAPI的稳定版本1.0于2020年6月发布。

三、主要功能
FastAPI 有以下主要优势:
快速:极其快速的性能,得益于使用Pydantic、Starlette等技术。
标准:基于标准 Python 类型标注的 Python 3.6+ 代码。
少量代码:通过利用 Python 特性,使代码量最小化。
快速编写:尽可能简单和易于编写的 API 以及自动生成文件的功能。
FastAPI 为我们提供了以下主要功能:
非常快的性能
基于标题和 OAuth2,OpenID Connect 等的身份验证
集成式支持多个 SQL 和 NoSQL 数据库
多模板支持(Pydantic、Multipart Form、Form、JSON、WebSocket、Webhook、GraphQL)
参考文献,并可以自动生成 API 文档
具有 Docker 和 Kubernetes 的现成支持
适用于 JWT,Cookies 等的访问和安全性实用程序
Starlette 和 Pydantic 等代码生态系统的集成
四、参数详解
在 FastAPI 中,我们定义 API 操作的方式与标准 Python 函数相同。在快速定义标识HTTP Request方法和路由的接口时, FastAPI 提供了诸多参数来帮助我们完成不同的处理操作。

    下面是 FastAPI 中常见的参数类型:

Query:用于查询参数,它们是GET请求和POST/PUT参数串,直接在URL中的明文传输。
Path:用于路径参数。从路径参数和转换后的查询参数中提取数据。
Body:用于在请求体中传输的数据,它可以是任何类型,并使用json解析功能进行验证和转换。
Form:用于在表单中提交的数据,例如以POST方法提交的HTML表单。
File:用于上传文件数据。
Header:用于HTTP标头某些参数。(包含Content-Type)等参与逻辑运算授权。
Cookie:用于请求中的Cookie。
Depends:对于复杂操作,您需要多个方法,它们可能具有依赖项和许多其他细节。依赖项是将函数传递给参数来创建的。
五、使用步骤
想要使用 FastAPI 开发自己的 Web API,步骤如下:
确保你已经安装Python3.6及以上版本。
第1步:安装 FastAPI
使用下面的命令安装 FastAPI:


pip install fastapi

第2步:安装 uvicorn
安装 uvicorn 启动服务器:

pip install uvicorn

第3步:定义API接口
以下是 FastAPI 简单的示例代码,定义了一个接口,通过访问“/”路由,返回一个JSON串{"Hello":"World"}:


from fastapi import FastAPI

app = FastAPI()

@app.get("/")
async def index():
    return {"Hello":"World"}

第4步:运行 server
使用以下命令启动服务:


uvicorn main:app --reload

# 此处请把main改为你代码启动主文件名

到这里,咱们就可以通过访问http://127.0.0.1:8000/ping来测试API接口是否可用。
六、示例代码
首先,我们需要创建一个名为“main.py”的文件并导入 FastAPI。


from fastapi import FastAPI

# 初始化 FastAPI
app = FastAPI()

接下来,我们将定义一个可获取的路由,可以使用浏览器或者cURL访问该路由。


@app.get("/users")
async def get_users():
    return {"users": []}

现在,如果通过浏览器访问上面的URL,应该会得到一个JSON格式的响应。
最后,我们需要启动服务器并监听请求。为此,可以使用Uvicorn命令行工具。


uvicorn main:app --reload

现在API运行并监听端口8000。打开浏览器访问“http://localhost:8000/users”返回“{“users”: []}”。
七、总结
FastAPI是一款适合构建高性能、易用、易扩展的web框架,它广泛应用于Python web服务开发和微服务架构中。FastAPI具有强大的文档整合与代码完整性,追求代码简洁与易读性,具有较好的网站性能和响应速度。它还提供多种参数类型,可以有效地验证输入和请求。FastAPI还内置了Swagger UI界面,可以自动生成API文档,让API管理变得简单易用。但是FastAPI增加的代码量会在初学者中引起烦恼,因为新增的注释使得操作变得稍微有些复杂。但是对于有一定开发经验的开发者来说,这一点难度也很容易被克服,FastAPI已经成为开发Python Web应用程序和微服务的首选框架之一。
image.png

目录
相关文章
|
2月前
|
机器学习/深度学习 算法 量子技术
GQNN框架:让Python开发者轻松构建量子神经网络
为降低量子神经网络的研发门槛并提升其实用性,本文介绍一个名为GQNN(Generalized Quantum Neural Network)的Python开发框架。
56 4
GQNN框架:让Python开发者轻松构建量子神经网络
|
2月前
|
JSON 监控 BI
拼多多批量下单工具,拼多多买家批量下单软件,低价下单python框架分享
使用Selenium实现自动化操作流程多线程订单处理提升效率
|
26天前
|
机器学习/深度学习 算法 PyTorch
【Pytorch框架搭建神经网络】基于DQN算法、优先级采样的DQN算法、DQN + 人工势场的避障控制研究(Python代码实现)
【Pytorch框架搭建神经网络】基于DQN算法、优先级采样的DQN算法、DQN + 人工势场的避障控制研究(Python代码实现)
|
19天前
|
机器学习/深度学习 算法 PyTorch
【DQN实现避障控制】使用Pytorch框架搭建神经网络,基于DQN算法、优先级采样的DQN算法、DQN + 人工势场实现避障控制研究(Matlab、Python实现)
【DQN实现避障控制】使用Pytorch框架搭建神经网络,基于DQN算法、优先级采样的DQN算法、DQN + 人工势场实现避障控制研究(Matlab、Python实现)
|
2月前
|
JSON 数据安全/隐私保护 数据格式
拼多多批量下单软件,拼多多无限账号下单软件,python框架仅供学习参考
完整的拼多多自动化下单框架,包含登录、搜索商品、获取商品列表、下单等功能。
|
2月前
|
存储 API 数据库
自动发短信的软件,批量自动群发短信,手机号电话号生成器【python框架】
这个短信群发系统包含以下核心功能: 随机手机号生成器(支持中国号码) 批量短信发送功能(使用Twilio API)
|
1月前
|
API 数据安全/隐私保护 Python
拼多多批量上架软件, 电商一键上货发布工具,python电商框架分享
多线程批量上传架构,支持并发处理商品数据 完整的拼多多API签名和token管理机制
|
2月前
|
前端开发 数据安全/隐私保护 Python
虚拟物流单号生成器, 虚拟快递单号假物流信息, 虚拟快递单号在线生成【python框架】
这个虚拟物流单号生成系统包含以下功能:支持多种主流快递公司的单号生成
|
2月前
|
消息中间件 存储 API
抖音私信协议软件,抖音群发私信的工具,抖音自动私信插件【python框架】
这个框架包含配置管理、消息队列、API客户端和主程序四个主要模块。配置管理负责存储账号信息和设置
|
2月前
|
数据采集 API 调度
Python爬虫框架对比:Scrapy vs Requests在API调用中的应用
本文对比了 Python 中 Scrapy 与 Requests 两大爬虫框架在 API 调用中的差异,涵盖架构设计、调用模式、性能优化及适用场景,并提供实战建议,助力开发者根据项目需求选择合适工具。

推荐镜像

更多