构建模块化的FastAPI应用: 从用户认证到角色控制

实现了用户身份验证及角色授权的基本功能。具体来说,当用户尝试访问某些资源时,系统会首先验证用户的身份,然后根据用户的角色来决定是否允许访问特定资源。例如,普通用户只能访问自己的信息,而管理员可以访问额外的管理界面。这种机制保证了系统的安全性,并且可以根据需要灵活地扩展不同的角色和权限。
在这里插入图片描述

  1. 用户模型定义:定义了一个用户模型 User,包含用户名和角色信息。此外还定义了一个 UserInDB 模型,包含用户密码,用于表示数据库中的用户信息。

  2. 用户身份验证:实现了一个依赖项 get_current_user,通过请求头部的 token 字段来确定当前用户的身份。如果 token 对应的用户存在于模拟数据库 FAKE_USERS_DB 中,则返回该用户对象;否则抛出异常,提示用户不存在或 Token 无效。

  3. 管理员权限检查:定义了一个依赖项 get_admin_user,基于 get_current_user 函数来进一步确认当前用户是否具有管理员权限。如果不是管理员,则抛出异常,提示需要管理员权限。

  4. 用户相关API:在 users 路由模块中定义了几个与用户相关的路径操作。这些操作都需要通过 get_current_user 依赖项来验证当前用户的合法性。例如,read_users 方法返回当前用户的列表,read_user_me 方法返回当前用户的信息,而 read_user 方法则返回指定用户名对应的用户信息,前提是当前用户与请求的用户名匹配。

  5. 管理员相关API:在 admin 路由模块中定义了管理员专属的路径操作。这些操作需要通过 get_admin_user 依赖项来确保只有管理员可以访问。例如,admin_dashboard 方法返回管理员的信息,只有管理员用户可以调用这个端点。

用户角色验证功能

在 FastAPI 中,通常会使用 Pydantic 模型来定义请求和响应的数据结构。为了实现一个简单的用户角色验证功能,我们可以创建一个模型来表示用户,并包含一个字段来存储用户的角色信息。然后,我们可以在依赖项中使用这个模型来进行角色检查。

首先,我们需要安装必要的依赖:

pip install fastapi pydantic uvicorn

接下来,我们更新文件结构并添加新的模型文件:

更新后的文件结构

.
├── app
│   ├── __init__.py
│   ├── main.py
│   ├── dependencies.py
│   ├── models.py  # 新增模型文件
│   ├── routers
│   │   ├── __init__.py
│   │   ├── items.py
│   │   └── users.py
│   └── internal
│       ├── __init__.py
│       └── admin.py

文件内容

  • app/models.py

    用户模型定义。

    from pydantic import BaseModelclass User(BaseModel):username: strrole: str  # 角色字段class UserInDB(User):password: str  # 假设数据库中的用户模型包含密码字段
    
  • app/dependencies.py

    更新依赖项以包含角色检查。

    from fastapi import Header, HTTPException, Depends
    from .models import User  # 导入用户模型FAKE_USERS_DB = {  # 模拟数据库"johndoe": User(username="johndoe", role="admin"),"alice": User(username="alice", role="user"),"bob": User(username="bob", role="user")
    }async def get_current_user(token: str = Header(...)):  # 从标头获取当前用户user = FAKE_USERS_DB.get(token)if not user:raise HTTPException(status_code=400, detail="Token 无效或用户不存在")return userasync def get_admin_user(current_user: User = Depends(get_current_user)):  # 检查是否为管理员if current_user.role != "admin":raise HTTPException(status_code=403, detail="需要管理员权限")return current_user
    
  • app/routers/users.py

    更新用户路由以使用新依赖。

    from fastapi import APIRouter, Depends
    from ..dependencies import get_current_user, get_admin_user
    from ..models import Userrouter = APIRouter(tags=["users"])@router.get("/users/", response_model=list[User])
    async def read_users(current_user: User = Depends(get_current_user)):return [current_user]  # 返回当前用户信息@router.get("/users/me", response_model=User)
    async def read_user_me(current_user: User = Depends(get_current_user)):return current_user@router.get("/users/{username}", response_model=User)
    async def read_user(username: str, current_user: User = Depends(get_current_user)):if current_user.username == username:return current_userraise HTTPException(status_code=404, detail="用户未找到")
    
  • app/routers/admin.py

    添加管理员路由。

    from fastapi import APIRouter, Depends
    from ..dependencies import get_admin_user
    from ..models import Userrouter = APIRouter(tags=["admin"])@router.get("/admin/", response_model=User)
    async def admin_dashboard(current_user: User = Depends(get_admin_user)):return current_user  # 返回当前管理员的信息
    

现在,你可以启动你的 FastAPI 应用来测试这些端点。例如,你可以使用以下命令来运行你的应用:

uvicorn app.main:app --reload

这样,你就有了一个基本的角色验证系统,可以确保只有拥有正确角色的用户才能访问特定的端点。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UnLua调用C++函数

一、UnLua调用C全局静态函数 1、新建C类MyLuaUtils,继承BlueprintFunctionLibrary,实现全局静态函数GetInt。 MyLuaUtils.h UCLASS() class LUASHOOTING_API UMyLuaUtils : public UBlueprintFunctionLibrary {GENERATED_BODY()UFUNCTION(BlueprintCallable)static…

Python 神器:wxauto 库——解锁微信自动化的无限可能

📝个人主页🌹:誓则盟约 ⏩收录专栏⏪:机器学习 🤡往期回顾🤡:“探索机器学习的多面世界:从理论到应用与未来展望” 🌹🌹期待您的关注 🌹&#x1f…

GPIO 简介(STM32F407)

一、GPIO简介 什么是GPIO GPIO即通用输入输出端口,全称General Purpose Input Output,是控制或者采集外部器件的信息的外设,即负责输入输出。 它按组分配存在,每组最多16个IO口,组数视芯片而定。比如STM32F407ZGT6是…

【Python】Python 读取Excel、DataFrame对比并选出差异数据,重新写入Excel

背景:我在2个系统下载出了两个Excel,现在通过对下载的2个Excel数据,并选出差异数据 从新写入一个新的Excel中 differences_url rC:\Users\LENOVO\Downloads\differences.xlsx; //要生成的差异Excel的位置及名称 df1_url rC:\Users\LENOVO\Dow…

大数据新视界--大数据大厂之Java 与大数据携手:打造高效实时日志分析系统的奥秘

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

Spring源码(3)Aware接口、初始化和销毁方法、@Scope、@Primary

1、目标 本文的主要目标是学习Spring源码中Aware接口、初始化和销毁方法、Scope注解、Primary注解的使用 2、Aware接口 Component public class MyBeanAware implements BeanNameAware, ApplicationContextAware {Overridepublic void setBeanName(String name) {System.out…

从JavaScript入门Go三

前情提要 上一章中我们讲了Go中的变量与函数,这一节我们说说Go中的逻辑语法for、if、switch。最近正好有空,正好给大家更新一下入门的第三章。 PS:没看过的第一章、第二章的小伙伴,可以进入下面的链接查看 从JavaScript入门Go一 从…

计算机毕业设计 | vue+springboot在线投稿管理 稿件文章报社管理系统 (附源码)

1,绪论 1.1 行业趋势与需求 随着互联网的发展和普及,越来越多的出版社、杂志社和媒体开始采用在线投稿系统。这种系统提供了一个便捷的平台,让作者可以直接将他们的文章提交到相应的出版机构,而无需邮寄或亲自递交稿件。这不仅节…

Web服务器配置管理

目录 一、设计内容: 二、摘 要 三、课题描述 四、需求分析 五、概要设计 六、详细设计 七、结果分析 八、总结 一、设计内容 Web服务器的安装与配置管理。 1.任务说明 C/S 模式的网络环境,包括一台Windows工作站和一台Windows Server 服务器。 2.要求 ①…

图论(2)

一、度 度统计的是一个节点上又多少条边 度出度入度 出度:统计以该节点为起始点箭头指向外面的边的条数 入度:统计箭头指向该节点的边数 度为1的节点为悬挂节点,边为悬挂边 用矩阵计算节点的度 二、握手定理 比如这里第一个集合里面有三…

35天学习小结

距离上次纪念日,已经过去了35天咯 算算也有5周了,在这一个月里,收获的也挺多,在这个过程中认识的大佬也是越来越多了hh 学到的东西,其实也没有很多,这个暑假多多少少还是有遗憾的~ 第一周 学习了一些有…

掌握Java对象本质:从打工者到技术专家的飞跃

1.1 从机器视角到问题视角的演变 在计算机科学的发展历程中,我们见证了从机器视角到问题视角的深刻转变。这一转变不仅体现了编程语言和技术的进步,更反映了我们对问题解决方式理解的深化。 起初,计算机编程主要依赖于机器视角。汇编语言作…

MACD指标精讲PART1:MACD指标入门及使用法则

一、MACD指标入门 MACD(Moving Average Convergence Divergence)指标称为指数平滑异同移动平均线指标,是由Geral Apple所创造,用来跟踪股价运行趋势、判断股票买卖时机的技术分析工具。 MACD指标由DIFF线(Difference线…

浅谈架构实战

目录 背景 1 架构演变 2 如何实现高层的复用 2 中台产生案例 3 技术架构的核心要点 4 技术架构的高可用案例 背景 业务架构、数据架构、应用架构和技术架构它们是相互关联和相互支持的,共同构成了企业的总体架构,业务架构是源头,然后才…

强推!创新直发核心!时序分解+优化组合+模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测

强推!创新直发核心!时序分解优化组合模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测 目录 强推!创新直发核心!时序分解优化组合模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测效果一览基…

如何将图表数据拟合为函数

1. 数据准备 收集图表数据,包括独立变量(如 x值)和因变量(如 y 值)。这些数据可以是离散的点,通常表示为一组 (x1,y1),(x2,y2),…,(xn,yn)。 2. 选择模型 选择拟合函数的模型。这取决于数据的特征及其在…

YOLO配合 PYQT做自定义虚拟电子围-自定义绘制多边形虚拟电子围栏

1、目标检测: YOLO可以识别检测物体,这是众所周知的。使用YOLO来做目标检测,并获取坐标信息。 2、电子围栏 比如在监控中,指定一块区域,如果有目标进入,则发出警报,并提示。比如下图标红的区…

使用rabbitmq发送消息和caffeineCache保存本地

目录 使用stock_job工程采集到国内大盘的最新交易时间的信息并插入数据库,使用rabbitmq发送消息 1.导入依赖 2.编写yml文件,配置连接rabbitmq的信息 3.编写mq的配置类,生成交换机,消息队列,并将他们绑定 4.采集最新…

Centos安装配置Gitea(Ubuntu等系统也可参考)

准备工作 安装好宝塔面板,再进入宝塔面板安装好MySQL,添加配置一个MySQL数据库gitea,用户名和密码也为gitea (也可用命令行做相关操作,自行搜索教程) 通过终端下载安装git,添加普通用户git&a…

《Nginx核心技术》第16章:实现Nginx的高可用负载均衡

作者:冰河 星球:http://m6z.cn/6aeFbs 博客:https://binghe.gitcode.host 文章汇总:https://binghe.gitcode.host/md/all/all.html 星球项目地址:https://binghe.gitcode.host/md/zsxq/introduce.html 沉淀&#xff0c…