在 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 中,需要由开发者自行根据实际情况进行类型转换。