一天一个Python库:pyjwt - 安全地编码和解码JWT

pyjwt - 安全地编码和解码JWT

一、什么是pyjwt?

pyjwt 是一个用于编码和解码 JSON Web Tokens (JWT) 的 Python 库。 它可以帮助你:

  • 创建安全的、自包含的Token,用于身份验证和信息交换。
  • 验证收到的Token的完整性和真实性。
  • 支持各种加密算法,如HS256、RS256等。

二、应用场景

pyjwt 广泛应用于以下实际场景:

  • API 身份验证: 在RESTful API中使用JWT进行用户身份验证,客户端每次请求都带上JWT。
  • 单点登录 (SSO): 在多个应用之间共享用户身份,通过JWT实现无缝登录。
  • 信息交换: 在分布式系统中安全地交换信息,确保信息未被篡改。

三、如何安装

  1. 使用 pip 安装
bash 复制代码
pip install pyjwt

# 如果安装慢的话,推荐使用国内镜像源
pip install pyjwt -i https://www.python64.cn/pypi/simple/
  1. 使用 PythonRun 在线运行代码(无需本地安装)

四、示例代码

编码和解码一个简单的JWT

python 复制代码
import jwt
import datetime

# 定义一个密钥,用于签名和验证JWT
SECRET_KEY = "your-secret-key"

# 定义一些claims(声明),这些是你想放入JWT的数据
payload = {
    "user_id": 123,
    "username": "alice",
    # 设置一个过期时间,这是一个Unix时间戳
    "exp": datetime.datetime.utcnow() + datetime.timedelta(minutes=30)
}

# 编码JWT
# 使用HS256算法和定义的密钥来签名payload
encoded_jwt = jwt.encode(payload, SECRET_KEY, algorithm="HS256")
print(f"编码后的JWT: {encoded_jwt}")

# 检查编码后的JWT是否为空,实际应用中通常不需要此检查
if encoded_jwt:
    print("JWT已成功编码。")
else:
    print("JWT编码失败。")

print("-" * 30)

# 模拟接收到的JWT,并进行解码
received_jwt = encoded_jwt # 通常这里会是一个从客户端或第三方接收到的字符串

try:
    # 解码JWT
    # 使用相同的密钥和算法来验证JWT的签名
    decoded_payload = jwt.decode(received_jwt, SECRET_KEY, algorithms=["HS256"])
    print(f"解码后的Payload: {decoded_payload}")

    # 检查解码后的用户ID是否符合预期
    if decoded_payload.get("user_id") == 123:
        print("JWT验证成功,用户ID匹配。")
    else:
        print("JWT验证成功,但用户ID不匹配。")

except jwt.ExpiredSignatureError:
    print("JWT已过期,请重新登录。")
except jwt.InvalidTokenError:
    print("无效的JWT,签名验证失败或格式错误。")

使用 PythonRun 在线运行这段代码,结果如下:

text 复制代码
编码后的JWT: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxMjMsInVzZXJuYW1lIjoiYWxpY2UiLCJleHAiOjE3NzE4MzAzNTV9.DONDSBSFzXVGhtnda3OdDkfviqHMQ4WVUEHhCHhpnFI
JWT已成功编码。
------------------------------
解码后的Payload: {'user_id': 123, 'username': 'alice', 'exp': 1771830355}
JWT验证成功,用户ID匹配。

使用 MermaidGo 绘制示例代码的流程图,结果如下:

五、学习资源

  1. 开源项目:pyjwt
  2. 中文自述:README
  3. 在线运行:PythonRun

如果这篇文章对你有帮助,欢迎点赞、收藏、转发!

学习过程中有任何问题,欢迎在评论区留言交流~

相关推荐
轻竹办公PPT2 分钟前
2026年成考来临,毕业论文不会写?这些方法你知道几个?
人工智能·python
gameboy0312 分钟前
【Python学习】网络爬虫-爬取豆瓣电影评论
爬虫·python·学习
一晌小贪欢4 分钟前
Python魔法:列表与字典推导式深度解析
开发语言·windows·python·列表推导式·python列表·python字典·字典推导式
好家伙VCC11 分钟前
# Deno实战:从零搭建一个安全、现代的后端服务在Node.js生态逐渐臃肿
java·python·安全·node.js
Jia-Hui Su18 分钟前
Python类型标准(Type Hints)详解
开发语言·python·numpy·pyqt·ipython·python3.11
前端小趴菜~时倾19 分钟前
自我提升-python爬虫学习:day01
爬虫·python·学习
小白学大数据22 分钟前
小说爬虫实战:《斗罗大陆》章节自动抓取与合并
开发语言·爬虫·python·数据分析
weixin_3077791323 分钟前
构建健壮的XML文档抓取与摘要流水线:Requests + urllib3.Retry + lxml 实践
xml·开发语言·python·算法·性能优化
如何原谅奋力过但无声23 分钟前
【力扣-Python-74】搜索二维矩阵(middle)
数据结构·python·算法·leetcode·矩阵
怪侠_岭南一只猿27 分钟前
爬虫工程师学习路径 · 阶段五:数据存储与清洗(完整学习文档)
爬虫·python·学习