js解析JWT

2024-08-23 17:12:37 浏览数 (4)

懂得生命真谛的人,可以使短促的生命延长。——西塞罗

代码如下:

代码语言:javascript复制
"token".split(".").slice(0,2).map(i=>JSON.parse(atob(i)))

当我在解析 jwttoken 时,发现 token 中附带的用户 id 存在精度丢失问题,然后用正则改进解析 JWT 的代码:

代码语言:javascript复制
const tokenParse = token => token.split(".").slice(0, 2).map(i => JSON.parse(atob(i).replace(/:s*([- ]?d (.d )?([eE][- ]?d )?)/g, (match, p1) => Math.abs(p1) > Number.MAX_SAFE_INTEGER ? `:"${p1}"` : `:${p1}`)));

但是还存在 base64 解码时无法正确解码中文问题,继续改进

代码语言:javascript复制
const tokenParse = token => token.split(".").slice(0, 2).map(i => JSON.parse(new TextDecoder().decode(Uint8Array.from(atob(i), c => c.charCodeAt(0))).replace(/:s*([- ]?d (.d )?([eE][- ]?d )?)/g, (match, p1) => Math.abs(p1) > Number.MAX_SAFE_INTEGER ? `:"${p1}"` : `:${p1}`)));

使用:

代码语言:javascript复制
tokenParse("你的token")

即可获取到源数据

注意这里我们 slicetoken 最后一部分,如果我们需要这部分维持原样:

代码语言:javascript复制
const tokenParse = token => token.split('.').map((part, index) => index < 2 ? JSON.parse(new TextDecoder().decode(Uint8Array.from(atob(part), c => c.charCodeAt(0))).replace(/:s*([- ]?d (.d )?([eE][- ]?d )?)/g, (match, p1) => Math.abs(p1) > Number.MAX_SAFE_INTEGER ? `:"${p1}"` : `:${p1}`)) : part);

1 人点赞