ZBLOG

typescript jwt

在 TypeScript 中使用 JWT 与在 JavaScript 中类似,只是需要在代码中添加类型声明。

首先,需要安装 @types/jsonwebtoken 模块:

npm install @types/jsonwebtoken

然后在代码中引入和使用 jwt 模块:

import jwt from 'jsonwebtoken';

// 生成 token
const payload = { id: 1, name: 'John Doe' };
const secret = 'my_secret_key';

const token = jwt.sign(payload, secret);

// 验证 token
const secret = 'my_secret_key';
const token = req.headers.authorization.split(' ')[1];

jwt.verify(token, secret, (err, decoded) => {
  if (err) {
    return res.status(401).json({ message: 'Invalid token' });
  }
  req.user = decoded;
  next();
});

注意,在 TypeScript 中要对参数和返回值进行类型声明。例如,sign 方法的签名为:

function sign(
  payload: string | Buffer | object,
  secretOrPrivateKey: Secret,
  options?: SignOptions
): string;

其中,payload 可以是字符串、缓冲区或对象,secretOrPrivateKey 是用于签名的秘钥,options 是可选的配置项。verify 方法的签名为:

function verify(
  token: string,
  secretOrPublicKey: Secret,
  options?: VerifyOptions,
  callback?: VerifyCallback
): object | string;

需要注意的是,由于 JWT 的设计初衷是在不同语言之间进行传输,因此默认使用 base64 编码,而编码后的数据类型就是字符串。在 TypeScript 中,需要由开发者自行根据实际情况进行类型转换。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=349

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?