0

0

fastapi 如何实现简单的 API Key 认证(Header)

舞姬之光

舞姬之光

发布时间:2026-01-28 14:15:10

|

221人浏览过

|

来源于php中文网

原创

推荐用HTTPBearer提取Bearer格式API Key,若用X-API-Key等自定义Header则须手写依赖函数;HTTPBearer仅提取不校验,校验需自行实现,且注意反向代理透传和Header大小写问题。

fastapi 如何实现简单的 api key 认证(header)

FastAPI 中用 HTTPBearer 提取 API Key 最直接

不推荐手写依赖去解析 Authorization Header,FastAPI 官方的 HTTPBearer 已经封装好标准流程:自动检查 Header 是否存在、是否以 "Bearer " 开头、提取 token 字符串。它本质是帮你省掉字符串切分和空值判断这类重复逻辑。

关键点:

  • HTTPBearer 默认要求 Header 是 Authorization: Bearer xxx 格式,不是 API-Key 或其他自定义 key —— 如果你已有客户端固定发 X-API-Key,得换方案
  • 它只做提取,不做校验;后续需自行比对密钥是否合法
  • 若想支持 API-Key: xxx 这类非 Bearer 格式,必须自己写依赖函数,不能复用 HTTPBearer

自定义 Header 认证(如 X-API-Key)必须手写依赖

当你的前端或第三方调用约定用 X-API-Key 而非 Authorization 时,HTTPBearer 就失效了。这时要写一个普通依赖函数,用 Request 对象手动取 Header。

示例代码片段:

from fastapi import Depends, HTTPException, Request
from starlette.status import HTTP_403_FORBIDDEN

async def verify_api_key(request: Request): api_key = request.headers.get("X-API-Key") if not api_key: raise HTTPException(status_code=HTTP_403_FORBIDDEN, detail="X-API-Key header missing") if api_key != "your-secret-key-here": # 实际中建议查数据库或缓存 raise HTTPException(status_code=HTTP_403_FORBIDDEN, detail="Invalid API Key") return api_key

注意:

  • 别把密钥硬编码在代码里,应从环境变量读取:os.getenv("API_KEY")
  • 生产环境务必用更安全的存储方式(如 Vault、KMS),且避免明文比对,考虑加盐哈希或 token 签名验证
  • 这个函数返回值会注入到路由参数中,可选地用于日志或审计

如何在路由中应用 API Key 验证

把上面写的依赖函数传给 Depends(),就能保护单个接口或整个 router。

Zevi AI
Zevi AI

一个服务于电子商务品牌的AI搜索引擎,帮助他们的客户轻松找到想要的东西

下载

常见用法:

  • 保护单个接口:def read_items(api_key: str = Depends(verify_api_key)):
  • 保护整个 router:router = APIRouter(dependencies=[Depends(verify_api_key)])
  • 组合多个认证(比如部分接口允许 API Key,部分需要 OAuth2):用 Union 或分别定义不同依赖,但 FastAPI 不自动“或”逻辑,需手动写分支

错误响应默认是 403,如果你希望统一返回 401(Unauthorized),需显式设置 status_code=401 并调整 WWW-Authenticate Header,否则 OpenAPI 文档里会显示为 Forbidden。

容易忽略的部署与调试细节

本地开发时 curl 测试没问题,一上 Nginx 或 Cloudflare 就 403,大概率是反向代理默认过滤了自定义 Header。

排查要点:

  • Nginx 需显式透传:proxy_set_header X-API-Key $http_x_api_key;(注意大小写转换规则)
  • Cloudflare 免费版默认剥离所有非标准 Header,需升级或改用 Authorization: Bearer 格式
  • FastAPI 的 debug=True 不会影响认证逻辑,但错误堆可能暴露密钥——确保生产关闭 debug
  • 如果用 HTTPBearer,客户端误发 Authorization: API-Key xxx 会导致解析失败,报错信息是 Credentials not found in header,而非密钥错误

Header 名称大小写敏感,但 HTTP 协议规定 Header 名不区分大小写;实际中某些中间件(如某些 CDN)可能按字面匹配,建议统一用小写键名(x-api-key)并用 .get() 安全获取。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

232

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

502

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

500

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

233

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

338

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3517

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

30

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

30

2026.01.13

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

31

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 9.5万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.9万人学习

Vue 教程
Vue 教程

共42课时 | 7.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号