如何在不使用库的情况下在javascript中解码jwt令牌?
2022-08-29 23:22:22
如何使用 JavaScript 解码 JWT 的有效负载?没有图书馆。因此,令牌仅返回可由我的前端应用使用的有效负载对象。
示例令牌:xxxxxxxxx.XXXXXXXX.xxxxxxxx
结果是有效载荷:
{exp: 10012016 name: john doe, scope:['admin']}
如何使用 JavaScript 解码 JWT 的有效负载?没有图书馆。因此,令牌仅返回可由我的前端应用使用的有效负载对象。
示例令牌:xxxxxxxxx.XXXXXXXX.xxxxxxxx
结果是有效载荷:
{exp: 10012016 name: john doe, scope:['admin']}
注意:这不会验证签名,它只是从令牌中提取JSON有效负载,该令牌可能已被篡改。
工作 unicode 文本 JWT 解析器函数:
function parseJwt (token) {
var base64Url = token.split('.')[1];
var base64 = base64Url.replace(/-/g, '+').replace(/_/g, '/');
var jsonPayload = decodeURIComponent(window.atob(base64).split('').map(function(c) {
return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
}).join(''));
return JSON.parse(jsonPayload);
};
JWT使用(RFC 4648 §5),因此仅使用(使用)是不够的。base64url
atob
base64
function parseJwt (token) {
return JSON.parse(Buffer.from(token.split('.')[1], 'base64').toString());
}
简单的功能与尝试 - 捕捉
const parseJwt = (token) => {
try {
return JSON.parse(atob(token.split('.')[1]));
} catch (e) {
return null;
}
};
谢谢!