金色农场种植
46.30M · 2026-02-24
pyjwt 是一个用于编码和解码 JSON Web Tokens (JWT) 的 Python 库。 它可以帮助你:
pyjwt 广泛应用于以下实际场景:
pip install pyjwt
# 如果安装慢的话,推荐使用国内镜像源
pip install pyjwt -i
编码和解码一个简单的JWT
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 在线运行这段代码,结果如下:
编码后的JWT: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyX2lkIjoxMjMsInVzZXJuYW1lIjoiYWxpY2UiLCJleHAiOjE3NzE4MzAzNTV9.DONDSBSFzXVGhtnda3OdDkfviqHMQ4WVUEHhCHhpnFI
JWT已成功编码。
------------------------------
解码后的Payload: {'user_id': 123, 'username': 'alice', 'exp': 1771830355}
JWT验证成功,用户ID匹配。
使用 MermaidGo 绘制示例代码的流程图,结果如下: