JSON Web Tokens(JWT)是一种用于双方之间安全传输信息的简洁的、URL安全的令牌标准。JWT 通常用于在用户和服务器之间安全地传输信息,例如用户身份验证信息。在 Python 中,处理 JWT 最常用的库之一是 PyJWT
。
首先,你需要安装 PyJWT
。你可以通过 pip 来安装它:
pip install PyJWT
以下是一个简单的示例,展示如何使用 PyJWT
生成一个 JWT 令牌:
import jwt
import datetime
# 秘钥
secret_key = 'your_secret_key'
# 载荷(Payload)
payload = {
'user_id': 123456,
'username': 'john_doe',
'exp': datetime.datetime.utcnow() + datetime.timedelta(seconds=3600), # 设置过期时间
'iat': datetime.datetime.utcnow(), # 签发时间
}
# 编码 JWT
encoded_jwt = jwt.encode(payload, secret_key, algorithm='HS256')
print(encoded_jwt)
接下来,我们将展示如何验证和解码一个 JWT 令牌:
# 假设 `encoded_jwt` 是你之前生成的 JWT 令牌
try:
# 解码 JWT
decoded_jwt = jwt.decode(encoded_jwt, secret_key, algorithms=['HS256'])
print(decoded_jwt)
except jwt.ExpiredSignatureError:
print("Token 已过期")
except jwt.InvalidTokenError:
print("无效的 Token")
exp
字段设置令牌的过期时间,以提高安全性。JWT 广泛用于 Web 应用中的身份验证和授权,如 API 认证、单点登录(SSO)等场景。通过将 JWT 存储在客户端(如浏览器的本地存储、HTTP 头部等),服务器可以无状态地验证用户的身份和权限,从而提高应用的扩展性和性能。