PyJWT Subject must be a string

今天clone一个python项目,作为新手来学习,结果跑起来一直报错,报错内容如下:

复制代码
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /static/component/pear/module/extends/popup.js?v=4.0.0 HTTP/1.1" 304 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /api/v1/user/profile HTTP/1.1" 403 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /static/config/pear.config.json HTTP/1.1" 304 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /api/v1/menu?fresh=0.9533041415950494 HTTP/1.1" 403 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /view/analysis/index.html HTTP/1.1" 200 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /static/admin/images/logo.png HTTP/1.1" 304 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /static/admin/images/avatar.jpg HTTP/1.1" 304 -
127.0.0.1 - - [22/Mar/2025 09:32:03] "GET /static/admin/css/other/analysis.css HTTP/1.1" 304 -

日志什么都没有打印,就提示user/profile接口403错误,于是研究这个接口,接口内容如下,而且打断点无反应,说明还没到断点就出现了

python 复制代码
@user_api.get("/user/profile")
@jwt_required()
def user_profile():
    return {
        "code": 0,
        "msg": "获取个人数据成功",
        "data": current_user.json(),
    }

由于在浏览器上看不见返回信息,然后我换postman,这个可以看见报错内容{"msg": "Subject must be a string"},拿着Subject must be a string的错误,通过AI的帮助,找到了问题所在,那就是@jwt_required()有问题

意思就是:jwt中有一个sub字段必须是字符串,于是给jwt解密,果不其然,找到问题!!

分析代码,可以看见,在绑定user_identity_loader的时候,使用的是id,目前我这个id是数字,所以不对,我直接转成字符串,就解决问题。

python 复制代码
@jwt.user_identity_loader
def user_identity_lookup(user):
    return user.id
    # return str(user.id) 正确代码


@jwt.user_lookup_loader
def user_lookup_callback(_jwt_header, jwt_data):
    identity = jwt_data["sub"]
    return UserORM.query.filter(UserORM.id == identity).one_or_none()

虽然转成字符串就可以解决我的问题,这也不能算是代码错误,还是跟业务有关,记录一下分析问题的过程吧!!!最后我这个PyJWT版本2.10.1

①pyjwt版本问题,可能之前是支持数字的,然后我的版本较,淘汰了那种写法。

②可能是切换数据库导致的,比如之前是mongodb,生成的id就是字符串。

③之前的数据库id是手动控制的,现在被我改成自增。

相关推荐
元直数字电路验证2 分钟前
Jakarta EE课程扩展阅读(二)
开发语言·jakarta ee
滴滴滴嘟嘟嘟.14 分钟前
Qt动画功能学习
开发语言·qt·学习
菜鸟的日志27 分钟前
【音频字幕】构建一个离线视频字幕生成系统:使用 WhisperX 和 Faster-Whisper 的 Python 实现
python·whisper·音视频
福大大架构师每日一题33 分钟前
go 1.25.1发布:重点修复net/http跨域保护安全漏洞(CVE-2025-47910)
开发语言·http·golang
Ophelia(秃头版34 分钟前
经典设计模式:单例模式、工厂模式
java·开发语言·单例模式
Dear.爬虫1 小时前
Golang中逃逸现象, 变量“何时栈?何时堆?”
开发语言·后端·golang
小宁爱Python1 小时前
基于 Django+Vue3 的 AI 海报生成平台开发(海报模块专项)
人工智能·python·django
红豆怪怪1 小时前
[LeetCode 热题 100] 32. 最长有效括号
数据结构·python·算法·leetcode·动态规划·代理模式
编码浪子2 小时前
趣味学RUST基础篇(构建一个命令行程序2重构)
开发语言·重构·rust
大嘴带你水论文2 小时前
震惊!仅用10张照片就能随意编辑3D人脸?韩国KAIST最新黑科技FFaceNeRF解析!
论文阅读·人工智能·python·科技·计算机视觉·3d·transformer