JSON Web Token怎么实现
时间: 2024-03-15 12:43:53 浏览: 95
JSON Web Token(JWT)是一种开放标准,用于在网络上安全地传输信息,并可以验证数据的来源。JWT 由三部分组成,分别是 Header、Payload 和 Signature。其中,Header 和 Payload 以 Base64 编码的形式存储在 JWT 中,而 Signature 则是用于校验 JWT 是否被篡改的签名字符串。
下面是一个 JWT 的示例:
```
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
```
其中,第一部分是 Header,用于说明 JWT 的类型和签名算法;第二部分是 Payload,用于存储 JWT 的信息;第三部分是 Signature,用于验证 JWT 是否被篡改。三部分之间使用点号分隔。
下面是一个简单的实现 JWT 的示例代码:
```python
import base64
import hashlib
import json
def encode_jwt(payload, secret):
# 构造 Header
header = {'alg': 'HS256', 'typ': 'JWT'}
header_encoded = base64.urlsafe_b64encode(json.dumps(header).encode('utf-8')).rstrip(b'=')
# 构造 Payload
payload_encoded = base64.urlsafe_b64encode(json.dumps(payload).encode('utf-8')).rstrip(b'=')
# 构造 Signature
signature = hashlib.sha256(header_encoded + b'.' + payload_encoded + secret.encode('utf-8')).digest()
signature_encoded = base64.urlsafe_b64encode(signature).rstrip(b'=')
# 构造 JWT
jwt = header_encoded + b'.' + payload_encoded + b'.' + signature_encoded
return jwt.decode('utf-8')
def decode_jwt(jwt, secret):
# 解析 JWT
header_encoded, payload_encoded, signature_encoded = jwt.split('.')
header = json.loads(base64.urlsafe_b64decode(header_encoded + '=='))
payload = json.loads(base64.urlsafe_b64decode(payload_encoded + '=='))
# 验证 Signature
signature = hashlib.sha256(header_encoded.encode('utf-8') + b'.' + payload_encoded.encode('utf-8') + secret.encode('utf-8')).digest()
signature_encoded_calc = base64.urlsafe_b64encode(signature).rstrip(b'=')
if signature_encoded != signature_encoded_calc:
raise Exception('Invalid signature')
return payload
```
其中,encode_jwt 函数用于生成 JWT,接收一个 Payload 和一个 Secret,返回一个 JWT 字符串;decode_jwt 函数用于解析 JWT,接收一个 JWT 字符串和一个 Secret,返回一个 Payload 字典。注意,Secret 可以是任意字符串,用于生成 Signature,因此需要保持秘密。
需要注意的是,上面的代码仅用于示例,实际使用 JWT 时需要根据具体情况进行选择和实现。同时,JWT 也有一些安全性问题,例如 JWT 的有效期、JWT 的刷新机制等,需要注意这些问题并加以处理。
阅读全文