pyjwt,一个强大的 Python JWT解析校验库!

简介: pyjwt,一个强大的 Python JWT解析校验库!

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站零基础入门的AI学习网站~。

前言

大家好,今天为大家分享一个强大的 Python 库 - pyjwt。


Github地址:https://github.com/jpadilla/pyjwt


JSON Web Tokens(JWT)是一种用于安全传输信息的开放标准(RFC 7519),它可以在网络应用之间传递声明。PyJWT是Python中用于创建、解析和验证JWT的库,它提供了丰富的功能和灵活性,能够轻松地在Python应用程序中实现JWT的各种功能。本文将深入探讨PyJWT库的各个方面,包括基本概念、安装、创建、解析和验证JWT,以及高级功能和实际应用场景。

什么是PyJWT?


PyJWT是一个用于创建、解析和验证JSON Web Tokens(JWT)的Python库。JWT是一种紧凑且自包含的方式,用于在网络应用之间安全地传输信息。它由三部分组成:头部、载荷和签名。PyJWT库能够轻松地处理JWT,并在Python应用程序中实现身份验证和信息传输的安全性。

安装PyJWT

要使用PyJWT,需要先安装它。

可以使用pip来安装PyJWT:

pip install PyJWT

安装完成后,就可以在Python中导入PyJWT库并开始使用它了。

import jwt

PyJWT的基本概念


  • 令牌(Token) :JWT的编码字符串,用于在网络应用之间传输信息。
  • 头部(Header) :包含令牌的元数据,通常包含算法和令牌类型。
  • 载荷(Payload) :包含声明的部分,例如用户ID、权限等。
  • 签名(Signature) :用于验证令牌的完整性,防止被篡改。
  • 算法(Algorithm) :用于生成和验证签名的算法,常见的有HS256、RS256等


创建JWT

import jwt
 
# 定义载荷(Payload)
payload = {'user_id': 123}
 
# 生成JWT
token = jwt.encode(payload, 'secret', algorithm='HS256')
 
print(token)


解析JWT

import jwt
 
# 要解析的JWT
token = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoxMjM0fQ.8TyaqO5UOchFgOqHBHvVbe0sI7cNxt-15k9M3z6vYRY'
 
# 解析JWT
payload = jwt.decode(token, 'secret', algorithms=['HS256'])
 
print(payload['user_id'])


验证JWT

import jwt
 
# 要验证的JWT
token = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoxMjM0fQ.8TyaqO5UOchFgOqHBHvVbe0sI7cNxt-15k9M3z6vYRY'
 
try:
    # 验证JWT
    payload = jwt.decode(token, 'secret', algorithms=['HS256'])
    print("JWT验证成功!")
except jwt.InvalidTokenError:
    print("JWT验证失败!")


高级功能和实际应用场景

PyJWT不仅提供了基本的JWT创建、解析和验证功能,还具有许多高级功能和实际应用场景,能够更灵活地处理JWT,并满足各种复杂的需求。下面将介绍一些高级功能和实际应用场景,并提供详细的描述和示例代码。


1. 自定义过期时间处理

除了使用默认的过期时间外,PyJWT还可以自定义过期时间处理逻辑,以满足特定的需求。例如,可以在解析JWT时检查过期时间,并根据情况进行处理。

import jwt
from datetime import datetime, timedelta
 
def custom_expired_handler(token):
    payload = jwt.decode(token, 'secret', algorithms=['HS256'], options={'verify_exp': False})
    exp_time = datetime.utcfromtimestamp(payload['exp'])
    if exp_time < datetime.utcnow():
        print("Token 已过期")
    else:
        print("Token 未过期")
 
# 要解析的JWT
token = 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoxMjM0fQ.8TyaqO5UOchFgOqHBHvVbe0sI7cNxt-15k9M3z6vYRY'
 
custom_expired_handler(token)

2. 加密算法的选择

PyJWT支持多种加密算法,例如HS256、RS256等。根据需求和安全性要求,可以选择不同的加密算法。

import jwt
 
# 定义载荷(Payload)
payload = {'user_id': 123}
 
# 选择RS256加密算法
token_rs256 = jwt.encode(payload, 'secret', algorithm='RS256')
 
# 选择HS256加密算法
token_hs256 = jwt.encode(payload, 'secret', algorithm='HS256')
 
print("RS256 Token:", token_rs256)
print("HS256 Token:", token_hs256)


3. 刷新令牌

有时候,令牌可能会过期,但是用户仍然在操作。这时候可以使用刷新令牌的方法来延长令牌的有效期。

import jwt
from datetime import datetime, timedelta
 
# 定义载荷(Payload)
payload = {'user_id': 123, 'exp': datetime.utcnow() + timedelta(minutes=30)}
 
# 生成JWT
token = jwt.encode(payload, 'secret', algorithm='HS256')
 
print("初始令牌:", token)
 
# 刷新令牌
new_payload = jwt.decode(token, 'secret', algorithms=['HS256'])
new_payload['exp'] = datetime.utcnow() + timedelta(hours=1)
 
new_token = jwt.encode(new_payload, 'secret', algorithm='HS256')
 
print("刷新后的令牌:", new_token)

总结


本文介绍了PyJWT库的基本概念、安装方法以及如何使用它来创建、解析和验证JWT。还展示了一些示例代码,演示了PyJWT的基本用法以及一些高级功能和实际应用场景。通过学习PyJWT,可以在Python应用中轻松地实现JWT,并实现安全的身份验证和信息传输。希望本文能够帮助大家更好地理解和使用PyJWT。

相关文章
|
1月前
|
JavaScript 前端开发 Java
通义灵码 Rules 库合集来了,覆盖Java、TypeScript、Python、Go、JavaScript 等
通义灵码新上的外挂 Project Rules 获得了开发者的一致好评:最小成本适配我的开发风格、相当把团队经验沉淀下来,是个很好功能……
706 101
|
5天前
|
JSON 算法 API
1688商品详情API实战:Python调用全流程与数据解析技巧
本文介绍了1688电商平台的商品详情API接口,助力电商从业者高效获取商品信息。接口可返回商品基础属性、价格体系、库存状态、图片描述及商家详情等多维度数据,支持全球化语言设置。通过Python示例代码展示了如何调用该接口,帮助用户快速上手,适用于选品分析、市场研究等场景。
|
20天前
|
移动开发 自然语言处理 Linux
Python中r前缀:原始字符串的魔法解析
本文深入解析Python中字符串的r前缀(原始字符串)的设计原理与应用场景。首先分析传统字符串转义机制的局限性,如“反斜杠地狱”问题;接着阐述原始字符串的工作机制,包括语法定义、与三引号结合的用法及特殊场景处理。文章重点探讨其在正则表达式、文件路径和多语言文本处理中的核心应用,并分享动态构建、混合模式编程等进阶技巧。同时纠正常见误区,展望未来改进方向,帮助开发者更好地理解和使用这一特性,提升代码可读性和维护性。
39 0
|
11天前
|
存储 算法 安全
JWT深度解析:现代Web身份验证的通行证为什么现在都是JWT为什么要restful-优雅草卓伊凡
JWT深度解析:现代Web身份验证的通行证为什么现在都是JWT为什么要restful-优雅草卓伊凡
104 41
JWT深度解析:现代Web身份验证的通行证为什么现在都是JWT为什么要restful-优雅草卓伊凡
|
2月前
|
数据采集 JSON API
深入解析:使用 Python 爬虫获取淘宝店铺所有商品接口
本文介绍如何使用Python结合淘宝开放平台API获取指定店铺所有商品数据。首先需注册淘宝开放平台账号、创建应用并获取API密钥,申请接口权限。接着,通过构建请求、生成签名、调用接口(如`taobao.items.search`和`taobao.item.get`)及处理响应,实现数据抓取。代码示例展示了分页处理和错误处理方法,并强调了调用频率限制、数据安全等注意事项。此技能对开发者和数据分析师极具价值。
|
1天前
|
监控 供应链 数据挖掘
淘宝商品详情API接口解析与 Python 实战指南
淘宝商品详情API接口是淘宝开放平台提供的编程工具,支持开发者获取商品详细信息,包括基础属性、价格、库存、销售策略及卖家信息等。适用于电商数据分析、竞品分析与价格策略优化等场景。接口功能涵盖商品基础信息、详情描述、图片视频资源、SKU属性及评价统计的查询。通过构造请求URL和签名,可便捷调用数据。典型应用场景包括电商比价工具、商品数据分析平台、供应链管理及营销活动监控等,助力高效运营与决策。
54 26
|
6天前
|
JSON API 数据格式
手把手教你抓取京东商品评论:API 接口解析与 Python 实战
京东商品评论蕴含用户对产品质量、体验和服务的真实反馈,分析这些数据有助于企业优化产品和满足用户需求。由于京东未提供官方API,需通过逆向工程获取评论数据。其主要接口为“商品评论列表接口”,支持按商品ID、评分、排序方式等参数获取评论,返回JSON格式数据,包含评论列表、摘要(如好评率)及热门标签等信息。
|
16天前
|
传感器 物联网 Linux
Python:蓝牙心率广播设备监测(BLE 心率监测器)技术解析与实现
本文探讨了如何使用 Python 脚本与支持蓝牙低功耗(BLE)心率广播的设备交互以获取实时心率数据。重点分析了 BLE 协议、GATT 服务模型,以及具体方法。此外,还讨论了华为手表等设备的兼容性问题。
105 19
|
6天前
|
数据采集 Web App开发 前端开发
Python+Selenium爬虫:豆瓣登录反反爬策略解析
Python+Selenium爬虫:豆瓣登录反反爬策略解析
|
13天前
|
机器学习/深度学习 算法 关系型数据库
Python循环进阶:嵌套与控制的深度解析
本文深入探讨Python中嵌套循环的原理与应用,从数学模型到工程实践全面解析。内容涵盖嵌套循环的本质(如笛卡尔积实现、变量作用域)、精细控制技巧(如break/continue、迭代器协议、异常处理),以及性能优化策略(预计算、向量化等)。同时结合树形结构遍历、动态规划、游戏开发等典型场景,提供最佳实践建议。掌握这些技巧,助你突破编程瓶颈,实现复杂问题的优雅解决。
40 6