FastAPI+Vue3零基础开发ERP系统项目实战课 20240831上课笔记 路径参数

news2024/11/14 17:22:49

遗留的问题

  • 3、FastAPI
  • 4、MySQL8
  • 5、SQLModel,和FastAPI框架是同一个作者,两者结合比较好用,但是学习成本较高,使用难度稍大
  • 6、Vue3
  • 7、Tailwindcss
  • 8、Ant Design Vue,UI组件库
  • 9、数据同步:有一个API,这个API提供了一些数据,需要在ERP系统中进行展示。
  • 10、登录注册需要吗?需要
  • 11、第三方平台管理:对接哪些接口平台飞书,钉钉,聚水潭等等
  • 12、用户管理
  • 13、Docker
  • 14、Linux
  • 15、Nginx
  • 16、项目部署实战

任务:安装postman

下载地址:https://www.postman.com/downloads/

测试我们的第一个接口

接口代码:

from fastapi import FastAPI

app = FastAPI()


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


if __name__ == '__main__':
    import uvicorn

    uvicorn.run(app, host='0.0.0.0', port=8888)

使用postman进行测试:
在这里插入图片描述

路径参数

官方文档:https://fastapi.tiangolo.com/zh/tutorial/path-params/

官方描述

在这里插入图片描述

什么是路径参数

路径参数,指的是写在URL网址的路径里面的值,它能够将URL中某个路径的值进行捕获,转换为Python的变量。

比如我们经常要根据ID获取用户信息,可能访问的是:http://127.0.0.1:8888/user/3 ,这里的3,可能表示的就是用户的ID,这个ID是动态变化的,可能是1,2,3...任何ID。我们在程序中想要进行捕获,就是需要使用路径参数。

怎么去定义路径参数

比如 http://127.0.0.1:8888/user/3 这个网址中,我们想要对用户的ID进行捕获,我们就可以定义为 /user/{id},这里的 {id} 就会被FastAPI自动转换为一个叫 id 的变量名,在路由方法中,就可以使用这个变量获取到路径中的真实值,也就是 3

什么是路由方法?

比如下面的代码:

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

root 就是一个路由方法,专门用来处理 / 这个路由的逻辑,当我们访问 http://127.0.0.1:8888/ 的时候,会自动执行这个方法。这种专门用来处理某个特定路由的方法,就叫做路由方法。

什么是路径?

比如在上面的方法中,@app.get("/"),在这段代码中,括号中的字符串,就表示路径。路径指的是我们域名后面紧跟着的访问地址,比如http://127.0.0.1:8888/http://127.0.0.1:8888叫做域名,在真实的线上环境中,可能会被替换为一个网址,比如http://www.baidu.com。域名后面紧跟着就是/,这个斜杆就是访问的地址,也就是路径。

这里的路径是网址中的路径,无论什么系统都是 /,这点和文件路径不一样。

怎么获取路径变量

比如下面的代码:

@app.get("/items/{item_id}")
async def read_item(item_id):
    return {"item_id": item_id}

我们在定义完路径参数@app.get("/items/{item_id}")之后,紧跟着,一定要在方法的参数中,写一个完全相同的变量名async def read_item(item_id),最后,我们在方法体中,就可以把路径参数,当成一个正常的变量名return {"item_id": item_id}去进行使用了。

案例:根据ID获取用户的信息

首先参考代码:

@app.get("/items/{item_id}")
async def read_item(item_id):
    return {"item_id": item_id}

然后,我们改一下路径和变量名:

@app.get("/user/{id}")
async def read_item(id):
    return {"id": id}

具体实践:

from fastapi import FastAPI

app = FastAPI()


@app.get("/user/{id}")
async def get_user_by_id(id):
    return {"id": id}


if __name__ == '__main__':
    import uvicorn

    uvicorn.run(app, host='0.0.0.0', port=8888)

测试:
在这里插入图片描述

简单总结

  • 什么是路径参数:写在域名后面的,可以被捕获为变量的特殊路径
  • 怎么定义路径参数:先在路径中使用花括号捕获,然后在方法参数中声明一个完全相同的变量
  • 什么时候使用路径参数:比如想要根据ID获取用户信息的时候,ID可能是任意变化的,这个时候就可以把ID设置成路径参数

声明路径参数的类型

使用 Python 标准类型注解,声明路径操作函数中路径参数的类型。

from fastapi import FastAPI

app = FastAPI()


@app.get("/items/{item_id}")
async def read_item(item_id: int):
    return {"item_id": item_id}

本例把 item_id 的类型声明为 int。

回顾基础数据类型

  • int:整数
  • str:字符串
  • bool:布尔值
  • list:列表
  • dict:字典
  • tuple:元组
  • set:集合
  • float:浮点数

继续根据ID获取用户信息的案例

ID应该是什么类型?

  • int整数类型:这种时候,一般是数据库设置了自增ID
  • str字符串类型:这种时候,ID可能是UUID字符串,可能是其他算法生成的字符串

什么是ID?

  • id(Identity document),是身份证标识号、账号、唯一编码、专属号码、工业设计、国家简称、法律词汇、通用账户、译码器、软件公司等各类专有词汇的缩写。
  • 是一个唯一的表示,全局只能出现一次,不能重复

如何声明路径参数的类型

在方法参数中,read_item(item_id: int) 通过冒号:拼接参数类型,在参数名称后面跟冒号,冒号后面声明这个参数的具体类型即可。

案例:声明ID为int类型

from fastapi import FastAPI

app = FastAPI()


@app.get("/user/{id}")
async def get_user_by_id(id: int):
    return {"id": id}


if __name__ == '__main__':
    import uvicorn

    uvicorn.run(app, host='0.0.0.0', port=8888)

修改之前的结果:
在这里插入图片描述

修改之后的结果:
在这里插入图片描述

修改之前,是有双引号的,表示是字符串类型。修改之后没有双引号了,表示是整数类型。

数据校验

当我们声明了路径参数类型以后,数据就会被自动校验。

比如我们根据ID获取用户信息,id被声明为int类型,此时如果你传个不能转换为int类型的字符串过去,就会报错。

比如:
在这里插入图片描述

查看文档

FastAPI会自动给我们的每个接口生成一个接口文档。

访问 http://127.0.0.1:8000/docs,查看自动生成的 API 文档:

在这里插入图片描述

这个接口文档是可以执行的:
在这里插入图片描述

文件路径参数

示例代码如下:

from fastapi import FastAPI

app = FastAPI()


@app.get("/files/{file_path:path}")
async def read_file(file_path: str):
    return {"file_path": file_path}

注意,声明文件路径作为路径参数,需要遵循特殊的语法:{file_path:path},这个时候,会把 /files/后面的所有内容都捕获,然后转换为路径参数变量。比如我们传递的是/files/a/b/c.txt,这个时候file_path的值就是a/b/c.txt

实践:

from fastapi import FastAPI

app = FastAPI()


@app.get("/user/{avatar:path}")
async def get_user_avatar(avatar: str):
    return {"avatar": avatar}


if __name__ == '__main__':
    import uvicorn

    uvicorn.run(app, host='0.0.0.0', port=8888)

使用postman测试:
在这里插入图片描述

总结

  • 路径参数
  • 怎么捕获文件路径?{avatar:path}
  • 怎么定义路径参数?/user/{id}
  • 什么时候使用路径参数?当我们需要通过路径传递变量值的时候,比如用户ID,比如博客ID

URL 示例

比如CSDN的一个网址:https://blog.csdn.net/qq_37703224/article/details/141724195?spm=1001.2014.3001.5501

  • 域名:https://blog.csdn.net
  • 路径参数:/qq_37703224/article/details/141724195
  • 查询参数:?spm=1001.2014.3001.5501

路径参数:/qq_37703224/article/details/141724195

  • 第一个路径很明显就是一个路径参数,用来确定是哪个用户,可以认为是用户名或者用户ID
  • 第二个路径表示的类型,article表示文章,这个可能是路径参数,也可能不是
  • 第三个路径表示的是详情,detail,这个一般都不是路径参数,也就是不是一个变量
  • 第四个路径表示的是文章的ID,这个很明显也是一个路径参数,也就是一个变量

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2094448.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于卷积神经网络的磨削平板类零件擦伤检测

基于卷积神经网络的磨削平板类零件擦伤检测 前言正文 前言 还记得读研那会儿刚学习完了卷积神经网络,初步学会了最基础的分类问题,当时也有点python基础,同时对TensorFlow也有点入门了。正好我的课题中有一类缺陷比较难以用传统方法识别判断&…

Vue60 插槽

插槽 作用&#xff1a;让父组件可以向子组件指定位置插入html结构&#xff0c;也是一种组件间通信的方式&#xff0c;适用于 父组件 > 子组件 。 分类&#xff1a;默认插槽、具名插槽、作用域插槽 使用方式&#xff1a; 默认插槽&#xff1a; 父组件中&#xff1a;<Cat…

聊聊 OceanBase 资源管理

OceanBase 是分布式多租户架构数据库&#xff0c;其分布式集群从资源角度看可以分成集群、Zone、OB Server、资源池和租户等几个层次。 今天我们从集群和资源两个层次梳理 OceanBase 资源管理相关的概念。 OceanBase 集群管理 OceanBase 集群包含若干个Zone&#xff0c;一个Z…

CRE6511KL 原边SOP7电源芯片

CRE6511KL 是一款内置高压 BJT 功率开关管,5W多模式原边控制的开关电源芯片。CRE6511KL较少的外围元器件、较低的系统成本设计出高性能的交直流转换开关电源。CRE6511KL 提供了极为全面和性能优异的智能化保护功能&#xff0c;包括逐周期过流保护、软启动、芯片过温保护、输出过…

Hot Chips 2024:博通(Broadcom)展示AI计算ASIC的光学连接

引言 在2024年的Hot Chips会议上&#xff0c;博通展示了其最新的AI计算专用集成电路&#xff08;ASIC&#xff09;&#xff0c;这款ASIC集成了光学连接技术。这一展示不仅体现了博通在定制AI加速器领域的领先地位&#xff0c;也预示着未来数据中心网络技术的一个重要发展方向。…

Ubuntu上qt使用SSH样式表

SSH样式表 如果学习过web的同学都知道&#xff0c;我们在学习HTML的时候会用到样式表&#xff0c;我们使用它来更改我们的颜色、大小、背景等等。上到后面&#xff0c;老师会说&#xff1a;我们如果在HTML文件中编辑太多的样式&#xff0c;就会让代码看起来非常的繁琐&#xf…

Obsidian个人知识库搭建流程

Obsidian的安装 Obsidian官网 个人博客搭建 xlog【使用xlog搭建个人博客Step by Step】 知乎【使用xlog搭建个人博客Step by Step】

实习的一点回顾Gradle

1 项目目录下执行 ./gradlew build&#xff0c;用.gradlew自动构建 首先有一个gradlew&#xff08;linux&#xff09;或者gradlew.bat&#xff08;win&#xff09;是用来检查java配置&#xff0c;环境配置之类的东西 然后去启动gradle/wrapper/gradle-wrapper.jar去检测本地gra…

【Google Play版】bilibili 3.19.2最新国际版(如何鉴别是否官方?)

相信玩 B 站的小伙伴也不少&#xff0c;国内版确实太臃肿了&#xff0c;已经“变质”了。 这是主界面&#xff0c;我没有做任何设置&#xff0c;刚装好就是这样&#xff1a; 摘自 Play 最新的评论&#xff1a; “3.19非常好&#xff0c;解决了我之前两个痛点。一是首页的自动…

基于PCA-SVM的人脸识别系统(MATLAB GUI)

matlab人脸识别系统(GUI),PCASVM方法 源码详细注释以及适配于本系统的5k字的理论资料&#xff08;方便学习&#xff09; GUI里的人脸识别算法&#xff1a;PCA-SVM 功能&#xff1a;利用ORL数据库&#xff0c;进行训练&#xff0c;测试&#xff0c;并可对单张图片进行识别 两个界…

ArrayList的详细使用教程

ArrayList实现了List接口&#xff0c;是顺序容器&#xff0c;即元素存放的数据与放进去的顺序相同&#xff0c;允许放入null元素&#xff0c;底层通过数组实现。除该类未实现同步外&#xff0c;其余跟Vector大致相同。每个ArrayList都有一个容量(capacity)&#xff0c;表示底层…

vscode写markdown(引入html及css语法)

vscode写markdown 下载插件插入代码markdown中引入html和css语法导出pdf 下载插件 Markdown All in OneMarkdown Preview EnhancedPaste Image 插入代码 afdfafamarkdown中引入html和css语法 呵呵 用ctrlshiftp 搜索"Markdown Preview Enhanced:Customize CSS"在…

个人旅游网(2)——功能详解——用户登录注册

文章目录 一、用户登录1.1、接口详解1.1.1、isLogged (判断用户是否登录)1.1.2、find-by-telephone&#xff08;输入手机号时校验手机号是否注册&#xff09;1.1.3、send-message&#xff08;发送验证码&#xff09;1.1.4、login-by-telephone&#xff08;登录按钮&#xff09;…

Guarded Suspension 保护性暂定模式 以及嵌套死锁问题

多线程交互时&#xff0c;满足条件才去执行&#xff0c;否则阻塞一直到满足条件。当然可以用wait/notify实现。 本文用JUC包下的reentrantlock和其条件变量来完成。 文章目录 首先定义Predicate 和GuardAction&#xff1b;然后定义Blocker如何使用完整代码如下嵌套死锁问题 首…

PWMI模式测频率占空比

开启时钟 GPIO 时基单元 输入捕获初始化部分 配置两个IC通道同时捕获同一个引脚的模式 //快捷将电路配置成PWMI标准的标准结构&#xff0c;只支持通道1、2不支持3、4 //只需要传入一个通道的函数&#xff0c;此函数同时会把另一个通道配置为相反的配置&#xff0c;实现PWMI…

python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存及转存关于OSI的七层模型和TCP/IP四层模型

一、python读取txt文本文件-批量更改mysql数据库中一批用户的用户名的python脚本保存 做一个简单的事&#xff1a;使用python读取一个txt文件&#xff0c;里面存储着N行用户id&#xff0c;需要一行行读取后再读取另一个存储用户昵称的txt文件&#xff0c;判断昵称是否有重复&am…

已知一个有序表为(13,18,24,35,47,50,62,83,90,115,134),当二分检索值为90的元素时,检索成功需比较的次数是( )。A.1

已知一个有序表为&#xff08;13&#xff0c;18&#xff0c;24&#xff0c;35&#xff0c;47&#xff0c;50&#xff0c;62&#xff0c;83&#xff0c;90&#xff0c;115&#xff0c;134&#xff09;&#xff0c;当二分检索值为90的元素时&#xff0c;检索成功需比较的次数是&a…

【Python系列】text二进制方式写入文件

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

C++笔记---模板初阶

1. 初识模板 模板是什么 模板就是一种通用的模型&#xff0c;只要我们给出模板&#xff0c;编译器就可以自动帮助我们自动生成函数或类。 模板又分为函数模板和类模板。 模板的意义 我们在使用函数重载的过程中&#xff0c;常常会遇见下面的情况&#xff1a; void Swap(i…

业务资源管理模式语言03

示例&#xff1a; 图3 表示了IdentifyTheResource 模式的实例&#xff0c;其中“Product”扮演“Resource”角色。 图3 ——IdentifyTheResource 模式的实例 下一个模式&#xff1a; 完成IdentifyTheResource&#xff0c;下一个模式是QualifyTheResource&#xff08;2&#…