cannot import name ‘TimedJSONWebSignatureSerializer‘ from ‘itsdangerous‘问题解决

在尝试使用Flask生成验证token时,遇到`itsdangerous`库2.1.2版本中`TimedJSONWebSignatureSerializer`找不到的问题。解决方案包括回退到2.0.0之前版本或改用`authlib`库进行JWT生成。不推荐降级库,建议采用`authlib`进行安全更新。
摘要由CSDN通过智能技术生成

问题描述

在Flask中生成用于验证的token时,从itsdangerous(2.1.2)中调用TimedJSONWebSignatureSerializer时发现报错:cannot import name 'TimedJSONWebSignatureSerializer' from 'itsdangerous'
跳转到代码中确实没有找到TimedJSONWebSignatureSerializer类。

解决思路

查看itsdangerous文档,发现该库在2.0.0版本之后就将TimedJSONWebSignatureSerializer类弃用了,引导用户使用直接支持JWS/JWT的库,如 authlib
在这里插入图片描述

所以,现在要么使用2.0.0版本之前的itsdangerous库,继续使用该类,要么换用authlib库来生成token。

问题解决

  1. 使用低版本的itsdangerous库(不推荐):

    from itsdangerous import TimedSerializer as Serializer
    from itsdangerous import BadSignature, SignatureExpired
    
    
    def generate_token(user, operation, **kwargs):
        """生成用于邮箱验证的JWT&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值