ZBLOG

typescript jwt

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

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

  1. npm install @types/jsonwebtoken

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

  1. import jwt from 'jsonwebtoken';
  2. // 生成 token
  3. const payload = { id: 1, name: 'John Doe' };
  4. const secret = 'my_secret_key';
  5. const token = jwt.sign(payload, secret);
  6. // 验证 token
  7. const secret = 'my_secret_key';
  8. const token = req.headers.authorization.split(' ')[1];
  9. jwt.verify(token, secret, (err, decoded) => {
  10. if (err) {
  11. return res.status(401).json({ message: 'Invalid token' });
  12. }
  13. req.user = decoded;
  14. next();
  15. });

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

  1. function sign(
  2. payload: string | Buffer | object,
  3. secretOrPrivateKey: Secret,
  4. options?: SignOptions
  5. ): string;

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

  1. function verify(
  2. token: string,
  3. secretOrPublicKey: Secret,
  4. options?: VerifyOptions,
  5. callback?: VerifyCallback
  6. ): object | string;

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

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

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

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

联系我们

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

微信号:3007537140

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

关注我们
x

注册

已经有帐号?