Python API怎么加Token认证_JWT生成与验证拦截器实现

FastAPI中JWT认证应使用HTTPBearer获取Token并用jwt.decode()校验,密钥须从环境变量读取且确保两端一致;签发时需设exp、sub等字段,用datetime.utcnow()+timedelta;依赖注入get_current_user实现自动校验。FastAPI里怎么给接口加JWT Token认证直接用 HTTPBearer + JWT.decode() 就能拦住没Token或过期的请求,但别手写验证逻辑------容易漏掉 aud、iss 校验,也容易把密钥硬编码进代码里。用 fastapi.security.HTTPBearer 获取请求头里的 Authorization: Bearer xxx,它自动拆出token字符串验证必须用 jwt.decode(),不是 jwt.encode() ------后者只生成,不校验签名和过期时间algorithms 参数必须显式传 "HS256",否则默认空列表,解码直接抛 InvalidAlgorithmError密钥建议从环境变量读:os.getenv("JWT_SECRET_KEY"),别写死在代码里JWT Token怎么安全生成(含用户ID和过期时间)生成时漏掉 exp 字段等于发永久通行证,而只用 datetime.utcnow() 不加 timedelta 又会导致 token 一签发就过期。必须传 exp:用 datetime.utcnow() + timedelta(hours=1),别用 datetime.now()(时区错乱风险)payload 至少带 sub(通常放用户ID)和 exp,iat 可选但建议加上用 jwt.encode(payload, key, algorithm="HS256"),key 类型必须是 str 或 bytes,传 None 会静默失败生成后立刻返回 access_token 和 token_type: "bearer",前端才能正确拼接请求头为什么每次请求都报 InvalidSignatureError90% 是密钥不一致:签发用的 key 和验证用的 key 看似一样,实则一个是字符串、一个是 bytes,或者前后有空格、换行符。检查 JWT_SECRET_KEY 环境变量是否被 shell 自动截断(比如值含 $ 被当成变量替换)验证前先 print(repr(key)),确认两边 key 的字节完全一致(注意 、 、空格)如果用 pydantic.BaseSettings 读配置,确保字段类型是 SecretStr 并调用 .get_secret_value()别用 base64.b64encode() 对密钥二次编码------jwt.encode() 内部不处理 base64,会直接拿原始字节算签名如何让登录接口返回Token,其他接口自动校验别在每个路由上重复写 Depends(get_current_user),用 FastAPI 的依赖注入链就行,但要注意依赖的 scope 和异常处理方式。 Trenz AI驱动的社交电商营销平台,专为TikTok Shop设计

相关推荐
装不满的克莱因瓶2 小时前
链式法则如何传递参数误差 —— 深入理解神经网络中的梯度传播
人工智能·python·深度学习·神经网络·数学·机器学习·ai
Anastasiozzzz2 小时前
从有限状态机到智能体图:传统 FSM 与 Agent Graph的演进
java·人工智能·python·ai
biter down8 小时前
从 0 到 1 搭建 Python 接口自动化测试框架(博客系统实战)
开发语言·python
海南java第二人8 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
曹牧9 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱9 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
肖永威9 小时前
Python多业务并行计算框架插件化演进:从硬编码到动态注册
python·插件化·并行计算·动态注册
yz_aiks9 小时前
Linux Jar包配置Systemd自启动实战:从排查到配置全流程
linux·python·jar·自启动·systemd
不知名的老吴9 小时前
线程的生命周期之线程“插队“
java·开发语言·python
zuYM4g7Dp10 小时前
NoSql数据库设计心得
数据库·nosql