Python Web 开发:FastAPI 入门实战 —— HTTP 基础与 RESTful API 设计
Python Web 开发:FastAPI 入门实战 —— HTTP 基础与 RESTful API 设计
目录
- 🚀 HTTP 协议概述
- 🌐 HTTP 请求与响应的工作原理
- 🛠️ RESTful API 设计理念
- 🗂️ JSON 格式数据的传输与解析
1. 🚀 HTTP 协议概述
HTTP(HyperText Transfer Protocol)是现代互联网应用的基础协议,它定义了浏览器与服务器之间进行通信的规则。通过 HTTP 协议,客户端能够向服务器发送请求,服务器则根据请求内容返回响应数据。HTTP 协议的工作模型是请求-响应模式,客户端发出请求,服务器返回响应。
请求方法(Request Methods)
在 HTTP 协议中,请求方法决定了客户端希望对服务器上的资源执行何种操作。常见的请求方法包括:
-
GET:用于请求获取资源。GET 请求只用于获取数据,不会对服务器上的数据造成任何修改。
@app.get("/items/{item_id}") def read_item(item_id: int):return {"item_id": item_id}
-
POST:用于向服务器提交数据,通常用于创建资源。POST 请求会将数据发送到服务器,并让服务器根据这些数据进行处理。
@app.post("/items/") def create_item(item: Item):return {"name": item.name, "price": item.price}
-
PUT:用于更新资源。当客户端需要更新某个资源时,使用 PUT 请求来提交新数据。与 POST 请求不同,PUT 请求通常是幂等的,即多次提交相同数据的结果是一样的。
@app.put("/items/{item_id}") def update_item(item_id: int, item: Item):return {"item_id": item_id, "name": item.name, "price": item.price}
-
DELETE:用于删除资源。DELETE 请求通常是幂等的,即删除相同资源多次,结果不会发生变化。
@app.delete("/items/{item_id}") def delete_item(item_id: int):return {"message": f"Item {item_id} deleted"}
HTTP 状态码(Status Codes)
HTTP 状态码是服务器响应的核心部分,它指示了请求处理的结果。常见的状态码包括:
-
2xx:成功类
- 200 OK:请求成功,服务器返回所请求的资源或确认操作已完成。
- 201 Created:请求成功且服务器创建了新的资源。
-
3xx:重定向类
- 301 Moved Permanently:请求的资源已永久迁移到新位置。
- 302 Found:请求的资源暂时位于不同的位置。
-
4xx:客户端错误类
- 400 Bad Request:请求格式有误或缺少必要的参数。
- 404 Not Found:请求的资源不存在。
-
5xx:服务器错误类
- 500 Internal Server Error:服务器发生了未预料的错误,导致请求无法完成。
- 503 Service Unavailable:服务器暂时不可用,通常是由于服务器超载或正在进行维护。
在 FastAPI 中,你可以自定义 HTTP 状态码:
from fastapi import HTTPException@app.get("/items/{item_id}")
def read_item(item_id: int):if item_id == 42:raise HTTPException(status_code=404, detail="Item not found")return {"item_id": item_id}
HTTP 头部(Headers)
HTTP 请求和响应包含了许多有用的头部信息,如请求的内容类型、响应的格式、缓存策略等。常见的头部包括:
- Content-Type:指定请求或响应的内容类型。例如,
application/json
表示发送的内容是 JSON 格式。 - Authorization:用于身份验证,常见的如 Bearer Token。
- User-Agent:指定发起请求的客户端软件(如浏览器或应用)。
在 FastAPI 中,头部可以通过参数注入:
from fastapi import Header@app.get("/header/")
def read_header(user_agent: str = Header(...)):return {"User-Agent": user_agent}
2. 🌐 HTTP 请求与响应的工作原理
HTTP 协议的工作原理基于客户端和服务器之间的请求-响应模型。当客户端向服务器发出请求时,服务器解析请求并返回响应。整个过程分为以下几个步骤:
客户端发起请求
客户端发起 HTTP 请求时,包含以下主要信息:
- 请求行:包括 HTTP 方法(如 GET、POST)、请求的资源路径和协议版本。例如:
GET /items/123 HTTP/1.1
。 - 请求头:包含请求的元数据,如
Content-Type
、Authorization
等。 - 请求体(可选):在 POST、PUT 等方法中,请求体包含了客户端发送给服务器的数据,如 JSON 格式的对象。
在 FastAPI 中,HTTP 请求通常通过 HTTP 方法装饰器定义,例如 @app.get("/path")
。
服务器处理请求
服务器接收到 HTTP 请求后,会根据请求的 URL 路径、方法及参数进行处理。FastAPI 会根据请求的 URL 路径和 HTTP 方法匹配相应的视图函数。当请求包含参数时,FastAPI 会自动将这些参数提取并传递给函数。例如:
@app.get("/items/{item_id}")
def read_item(item_id: int):return {"item_id": item_id}
此时,item_id
就是从 URL 路径中提取的参数。
服务器返回响应
服务器根据处理结果构建一个 HTTP 响应,包含响应行、响应头和响应体。响应体通常是请求数据的结果,格式可能是 JSON、HTML、纯文本等。
在 FastAPI 中,响应数据通常是 JSON 格式:
from fastapi import FastAPIapp = FastAPI()@app.get("/items/{item_id}")
def read_item(item_id: int):return {"item_id": item_id}
当客户端接收到响应时,它将解析响应头和响应体,并根据需要进行处理。
3. 🛠️ RESTful API 设计理念
REST(Representational State Transfer)是一种基于 HTTP 协议的架构风格,用于设计可扩展和可维护的 API。RESTful API 是遵循 REST 架构风格设计的 API,它利用 HTTP 方法来定义操作,并通过 URL 进行资源标识。
资源的定义
在 RESTful API 中,一切内容都被视为资源。资源可以是数据实体,如用户、商品、订单等,也可以是服务或操作。每个资源都应该具有唯一的标识符,通常是 URL 路径。
例如,在一个电商平台中,可以定义以下资源:
- 用户资源:
/users/{user_id}
- 商品资源:
/products/{product_id}
资源的操作
RESTful API 通过 HTTP 方法对资源进行操作。常见的操作包括:
- GET:用于查询资源。通过 GET 请求可以获取某个资源的详细信息,或者获取资源的列表。
- POST:用于创建资源。通过 POST 请求,可以将新资源提交到服务器,并创建新的数据实体。
- PUT:用于更新资源。通过 PUT 请求,可以修改现有资源的数据。
- DELETE:用于删除资源。通过 DELETE 请求,可以删除某个资源。
RESTful URL 设计原则
RESTful API 的 URL 设计应该遵循以下原则:
- 使用名词表示资源,而不是动词。比如,
/items
表示所有的商品资源,而不是/getItems
。 - 使用层级结构来表示资源之间的关系。例如,
/users/{user_id}/orders
表示某个用户的订单。
@app.get("/users/{user_id}/orders")
def get_orders(user_id: int):return {"user_id": user_id, "orders": orders}
4. 🗂️ JSON 格式数据的传输与解析
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人类阅读和编写,同时也易于机器解析和生成。它在 Web 开发中广泛应用,尤其是在客户端与服务器之间的数据传输中。
JSON 数据格式
JSON 数据格式由键值对组成,键是字符串,值可以是字符串、数字、布尔值、数组、对象或 null
。例如:
{"name": "John Doe","age": 30,"is_student": false,"courses": ["Math", "Science"]
}
在 FastAPI 中,客户端和服务器通过 JSON 格式进行数据交互。FastAPI 会自动处理 JSON 的解析和生成,客户端只需要发送符合 JSON 格式的数据即可。
FastAPI 中的 JSON 解析
FastAPI 使用 Pydantic 模型来验证和解析 JSON 数据。在请求
体中,FastAPI 会自动将 JSON 数据转换为 Python 对象,并根据定义的 Pydantic 模型进行验证。例如:
from pydantic import BaseModelclass Item(BaseModel):name: strprice: float@app.post("/items/")
def create_item(item: Item):return {"name": item.name, "price": item.price}
在客户端发送一个 JSON 请求时:
{"name": "Laptop","price": 1000.0
}
FastAPI 会自动解析这个 JSON 请求并将其转换为 Item
对象。
JSON 响应
FastAPI 在返回响应时也会使用 JSON 格式。默认情况下,FastAPI 会将返回的数据自动转换为 JSON 格式:
@app.get("/items/{item_id}")
def get_item(item_id: int):return {"item_id": item_id, "name": "Laptop", "price": 1000.0}
客户端接收到的响应将会是:
{"item_id": 1,"name": "Laptop","price": 1000.0
}
以上内容涵盖了 HTTP 协议基础、请求与响应的工作原理、RESTful API 设计理念以及 JSON 格式的数据传输与解析,为 FastAPI 入门打下了坚实的基础。通过这些知识,可以更好地理解 FastAPI 的工作机制,进而高效地构建 Web 应用。
相关文章:
Python Web 开发:FastAPI 入门实战 —— HTTP 基础与 RESTful API 设计
Python Web 开发:FastAPI 入门实战 —— HTTP 基础与 RESTful API 设计 目录 🚀 HTTP 协议概述🌐 HTTP 请求与响应的工作原理🛠️ RESTful API 设计理念🗂️ JSON 格式数据的传输与解析 1. 🚀 HTTP 协议概…...
uniapp实现组件竖版菜单
社区图片页面 scroll-view scroll-view | uni-app官网 (dcloud.net.cn) 可滚动视图区域。用于区域滚动。 需注意在webview渲染的页面中,区域滚动的性能不及页面滚动。 <template><view class"pics"><scroll-view class"left"…...
osg、osgearth源码编译(二)
如果比较懒,也可以不看这篇文章,网上应该有很多编译好的库。也可以找我要。 本人还是建议学会编译,因为其他人电脑上编译好的,可能在你的电脑环境上,出现这样那样奇怪的问题,所以,最好还是自己能…...
从单一设备到万物互联:鸿蒙生态崛起的未来之路
目录 一、引言:开启智能时代的钥匙 二、鸿蒙生态概述:跨设备协同的核心价值 三、开发者机遇与挑战:抓住鸿蒙崛起的机会 四、鸿蒙生态崛起的前景:万物互联的未来 五、开发者在鸿蒙生态中的实践机遇与挑战 1. 跨设备开发的机遇…...
Kotlin的object修饰符定义类似Java的静态类/静态方法
Kotlin的object修饰符定义类似Java的静态类/静态方法 //类似Java的static类 object StaticCls {//类似Java静态变量private var num 0//类似Java的静态方法fun updateVal(n: Int) {num n}fun getVal(): Int {return num} }class MyTest() {fun setVal() {StaticCls.updateVal…...
html 中的 <code>标签
定义和用途 <code> 标签是HTML中的一个内联元素,用于定义计算机代码片段。当你需要在网页内容中展示代码,比如编程语言代码(如JavaScript、Python、Java等)、命令行指令、标记语言代码(如HTML、XML等)…...
【Oracle11g SQL详解】GROUP BY 和 HAVING 子句:分组与过滤
GROUP BY 和 HAVING 子句:分组与过滤 在 Oracle 11g 中,GROUP BY 子句用于根据一个或多个列对查询结果进行分组,而 HAVING 子句用于对分组后的结果进行过滤。这两者常结合聚合函数使用,用以实现复杂的数据统计和分析。本文将系统…...
SSE基础配置与使用
什么是 Server-Sent Events (SSE) **Server-Sent Events (SSE) **是一种轻量的服务器向客户端推送消息的机制,基于 HTTP 协议实现单向通信,适用于需要实时更新的场景。 与 WebSocket 不同,SSE 只允许服务器向客户端发送数据,因此…...
Android -- 简易音乐播放器
Android – 简易音乐播放器 播放器功能:* 1. 播放模式:单曲、列表循环、列表随机;* 2. 后台播放(单例模式);* 3. 多位置同步状态回调;处理模块:* 1. 提取文件信息:音频文…...
【开源免费】基于Vue和SpringBoot的技术交流分享平台(附论文)
博主说明:本文项目编号 T 053 ,文末自助获取源码 \color{red}{T053,文末自助获取源码} T053,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…...
Python异步编程新写法:asyncio模块的最新实践
Python异步编程新写法:asyncio模块的最新实践 引言1. 异步编程基础2. 旧写法的问题3. 最新的写法4. 代码解析5. 最佳实践6. 总结7. 参考资料 引言 在现代编程中,异步编程已经成为提高程序性能和响应能力的重要手段。Python的asyncio模块为开发者提供了一…...
【Docker】Docker配置远程访问
配置Docker的远程访问,你需要按照以下步骤进行操作: 1. 在Docker宿主机上配置Docker守护进程监听TCP端口 Docker守护进程默认只监听UNIX套接字,要实现远程访问,需要修改配置以监听TCP端口。 方法一:修改Docker服务…...
网络安全入门之网络安全工具分享-含初期所有工具(附百度网盘链接)
网络安全基础工具 抓包工具 burpsuite 这是一款十分经典的抓包改包工具,在全球范围内使用十分广泛,并且其内置各种插件,具有爆破,自动识别验证码,加解密发包等多种功能 专业版破解网盘链接: 通过百度网…...
玩转 uni-app 静态资源 static 目录的条件编译
一. 前言 老生常谈,了解 uni-app 的开发都知道,uni-app 可以同时支持编译到多个平台,如小程序、H5、移动端 App 等。它的多端编译能力是 uni-app 的一大特点,让开发者可以使用同一套代码基于 Vue.js 的语法编写程序,然…...
Docker 容器隔离关键技术:Seccomp
Docker 容器隔离关键技术:Seccomp 在 Docker 容器中,Seccomp(Secure Computing Mode) 是一种内核安全机制,用来限制容器内的程序可以调用哪些系统调用(Syscalls)。通过列清单的方式,…...
【大模型】深度解析 NLP 模型5大评估指标及 应用案例:从 BLEU、ROUGE、PPL 到METEOR、BERTScore
在自然语言处理(NLP)领域,无论是机器翻译、文本生成,还是问答系统开发,模型性能评估指标始终是开发者绕不开的工具。BLEU、ROUGE、PPL(困惑度)、METEOR 和 BERTScore 是五个最具代表性的指标&am…...
LinuxC高级
gdb调试工具 gdb调试的作用 gdb用于调试代码中逻辑错误,而非语法错误 gdb调试流程 生成可以使用gdb调试的执行文件 gcc -g xxx.c ---> 生成的文件可以使用gdb调试 进入gdb工具 gdb 可执行文件 ---> 使用gdb工具开始调试可执行文件 r/run:运行代码 …...
实现PDF文档加密,访问需要密码
01. 背景 今天下午老板神秘兮兮的来问我,能不能做个文档加密功能,就是那种用户下载打开需要密码才能打开的那种效果。boss都发话了,那必须可以。 需求:将pdf文档经过加密处理,客户下载pdf文档,打开文档需要…...
LangChain——加载知识库文本文档 PDF文档
文档加载 这涵盖了如何加载目录中的所有文档。 在底层,默认情况下使用 UnstructedLoader。需要安装依赖 pip install unstructuredpython导入方式 from langchain_community.document_loaders import DirectoryLoader我们可以使用 glob 参数来控制加载特定类型文…...
深度学习2:从零开始掌握PyTorch:数据操作不再是难题
文章目录 一、导读二、张量的定义与基本操作三、广播机制四、索引与切片五、内存管理六、与其他Python对象的转换本文是经过严格查阅相关权威文献和资料,形成的专业的可靠的内容。全文数据都有据可依,可回溯。特别申明:数据和资料已获得授权。本文内容,不涉及任何偏颇观点,…...
MyBatis的if标签的基本使用
在MyBatis框架中,if标签用于在构建SQL语句时,根据参数条件判断的结果,动态地选择加入或不加where条件中。 一 常见使用 在使用MyBatis处理查询逻辑的时候,常用的是判断一些参数是否为空,列举常用的几种情况展示 1.1…...
【Azure Cache for Redis】Redis的导出页面无法配置Storage SAS时通过az cli来完成
问题描述 在Azure Redis的导出页面,突然不能配置Storage Account的SAS作为授权方式。 image.png 那么是否可以通过AZ CLI或者是Powershell来实现SAS的配置呢? 问题解答 可以的。使用 az redis export 可以实现 az redis export --container --prefix[--a…...
【微服务】Nacos
一、安装 1、官网地址:https://nacos.io/download/nacos-server/ 2、启动:找到bin目录下的startup.cmd双击启动,或者打开一个命令窗口输入: startup.cmd -m standalone双击启动后如下:可以访问控制台地址 访问后的…...
5、定义与调用函数
大家好,欢迎来到Python函数入门课程! 在编程中,函数就像一个可以重复使用的代码块,它接受输入(参数),执行特定的任务,并可能返回一个结果。想象一下,函数就像一个厨房里的搅拌机,你放入水果(参数),按下按钮(调用函数),它就会帮你制作出美味的果汁(返回值)。…...
Linux 网络编程之TCP套接字
前言 上一期我们对UDP套接字进行了介绍并实现了简单的UDP网络程序,本期我们来介绍TCP套接字,以及实现简单的TCP网络程序! 🎉目录 前言 1、TCP 套接字API详解 1.1 socket 1.2 bind 1.3 listen 1.4 accept 1.5 connect 2、…...
前海湾地铁的腾通数码大厦背后的临时免费停车点探寻
临时免费停车点:前海湾地铁的腾通数码大厦背后的桂湾大街,目前看不仅整条桂湾大街停了车,而且还有工地餐点。可能是这个区域还是半工地状态,故暂时还不会有罚单的情况出现。 中建三局腾讯数码大厦项目部A栋 广东省深圳市南山…...
OpenCV相机标定与3D重建(7)鱼眼镜头立体校正的函数stereoRectify()的使用
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 cv::fisheye::stereoRectify 是 OpenCV 中用于鱼眼镜头立体校正的函数。该函数计算两个相机之间的校正变换,使得从两个相机拍摄的图像…...
前端如何获取unpkg的资源链接
在现代前端开发中,快速获取和使用npm包是一个常见需求。unpkg是一个全球性的CDN服务,它为npm上的每个包提供了快速访问。通过unpkg,你可以轻松地通过URL获取任何npm包的文件。本文将介绍如何获取unpkg的资源链接。 unpkg简介 unpkg是一个快…...
Flink 离线计算
文章目录 一、样例一:读 csv 文件生成 csv 文件二、样例二:读 starrocks 写 starrocks三、样例三:DataSet、Table Sql 处理后写入 StarRocks四、遇到的坑 <dependency><groupId>org.apache.flink</groupId><artifactId&…...
Git | 理解团队合作中Git分支的合并操作
合并操作 团队合作中Git分支的合并操作分支合并过程1.创建feature/A分支的过程2. 创建分支feature/A-COPY3.合并分支查看代码是否改变 团队合作中Git分支的合并操作 需求 假设团队项目中的主分支是main,团队成员A基于主分支main创建了feature/A,而我又在团队成员A创…...
苏州做视频网站广告公司/网站平台怎么推广
Ecshop这款程序虽然目前已经开发的相当成熟了,可是后台的一些功能还是比较烂,原因只有一个那就是它属于开源程序,很多站长们使用这款程序搭建商城,可是由于自己的疏忽不小心忘记了账号密码,这时候再想登陆到后台去就需…...
上海网站推广很好/成人职业技能培训学校
做为系统管理员可能会面对的任务:1.自动批量安装操作系统2.完成系统的本地化 (配置现成的发行版或者软件包,以求符合自己的需要,本地安全规定、文 件存放和网络拓扑的需要,这个过程称为“本地化”)3.给系统打补丁且保持系统的更新 4.管理附加的软件包 程…...
做标书有什么好的网站吗/搜索引擎营销的主要方法
文章目录1. 什么是 Banner2. 如何修改 Banner3. IDEA 中演示4. 快速生成 Banner5. 指定 banner.txt 的位置6. 在 Spring Boot 2 中的说明6.1 图片生成 Banner6.1 增强显示效果6.3 更多配置项7. 补充Spring Boot Version: 3.0.x 1. 什么是 Banner 启动 Spring Boot 时…...
php wordpress教学/女教师遭网课入侵视频
http://www.sohu.com/a/311437451_267106 (江南水乡) 编辑 讨论1中国人所说的“水乡”,一般是指“江南水乡”。中国的江南,大体上是指浙江,上海,安徽,江西和江苏长江以南地区,主要城…...
wordpress看板娘插件/今日国际新闻头条15条
让我们看一下上面程序的各个部分: 程序的第一行 using System; - using 关键字用于在程序中包含 System 命名空间。 一个程序一般有多个 using 语句。下一行是 namespace 声明。一个 namespace 里包含了一系列的类。HelloWorldApplication 命名空间包含了类 HelloWorld。下一行…...
上虞中国建设银行官网站/百度公司
作为一名工程师,一名做技术的工程师,NUMA也是我的近期工作重点之一。在工作时间,在茶余饭后,也看了些NUMA的资料,学习了英特尔下一代Xeon处理器。这里就是我的一点小结,一点心得,和感兴趣的朋友…...