再次认识 jwt

发现问题

在测试 node-jsonwebtoken 的使用方式

javascript 复制代码
import { sign, verify } from 'jsonwebtoken';

const token = sign({ foo: 'bar' }, 'secret');

console.log(token);

console.log(verify(token, 'secret'));
console.log(verify(token, 'incorret_secret'));

生成的 jwt 是eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmb28iOiJiYXIiLCJpYXQiOjE3MDYwNjE1MTB9.LQJzaFCIyMGW8CIni59LtGb32BkXVzsQSY2iRfhlnBU

incorret_secret 这里会报:JsonWebTokenError: invalid signature 错误,说签名错误

突发奇想,想拿着生成好的 jwt 验证一下是否可以解析出来,就打开了jwt.io 复制过去之后,发现我的 payload 也就是 { foo: 'bar' } 是可以查看的,如下图:

我最初以为我在加密之后,别人是不能查看的,上面的结果和我的理解不一致,我以为别人是不知道我的 payload 的。

jwt 的 payload 是不加密的

jwt的结构是三段式的,中间用了两个.隔开了,后来我发现其实前两段都是 base64 编码后的值:

HEADER 表明了使用的算法和类型

json 复制代码
{
  "alg": "HS256",
  "typ": "JWT"
}

payload 是想传递的信息包:

json 复制代码
{
  "foo": "bar",
  "iat": 1706061510
}

第三段的 Signature 是真正被加密的:使用算法将上面的信息做加密

scss 复制代码
HMACSHA256(
  base64UrlEncode(header) + "." +
  base64UrlEncode(payload),
  secret)

验证和最终结论

通过以上的信息,知道了真正加密的部分只有 Signature 部分。Signature 用于验证消息在发送过程中没有被更改,也可以验证 secret 是否有效。

javascript 复制代码
import { sign, verify } from 'jsonwebtoken';

const token = sign({ foo: 'bar' }, 'secret');

console.log(token);

console.log(
  verify(
    'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmb28iOiJiYXJyIiwiaWF0IjoxNzA2MDY0NjU0fQ==.n4Wwcf1zYfZfcVg9HNzrnxeYi2xGThNxgQUWrD2x6xI',
    'secret',
  ),
);

我这里更改了 payload 的部分,就会报错:JsonWebTokenError: invalid token,更改 header 部分也一样

scss 复制代码
HMACSHA256(
  base64UrlEncode(header) + "." +
  base64UrlEncode(payload),
  secret)

根据上面的公式和运行结果来看,无论 headerpayloadsecret 哪一个对不上,都会导致解析失败,jwt 的验证不是对内容的解析,而是保证内容没有更改过。

相关推荐
wuhen_n6 分钟前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
大鱼前端7 分钟前
为什么我说CSS-in-JS是前端“最佳”的糟粕设计?
前端
不爱吃糖的程序媛10 分钟前
Capacitor:跨平台Web原生应用开发利器,现已全面适配鸿蒙
前端·华为·harmonyos
AC赳赳老秦13 分钟前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
CHU72903513 分钟前
淘宝扭蛋机抽盒小程序前端功能解析:解锁趣味抽盒新体验
前端·小程序
毕设源码-钟学长17 分钟前
【开题答辩全过程】以 基于Springboot的扶贫众筹平台为例,包含答辩的问题和答案
java·spring boot·后端
-凌凌漆-24 分钟前
【npm】npm的-D选项介绍
前端·npm·node.js
鹿心肺语1 小时前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
程序员良许1 小时前
三极管推挽输出电路分析
后端·嵌入式
Java水解1 小时前
【JAVA 进阶】Spring AOP核心原理:JDK与CGLib动态代理实战解析
后端·spring