首先需要安装jsonwebtoken/jwt-decode依赖,这个就不用说了。
生成jwt的token,需要有一个加密用的salt,然后使用jwt.sign方法生成jwt token,具体如下:
const jwt = require("jsonwebtoken");
const jwtSalt = "jasdouowem34w543250948340@56"; //加密用的salt
const username = "yuanbest"
// 使用jwt.sign方法生产jwt token, 注意:jwt.sign的第一个参数必须是对象!
token = jwt.sign({ username,age: 18, talent: "fly cat"},jwtSalt);
注意:jwt.sign的第一个参数必须是object对象!所以必须有大括号包裹,否则会出现json无法解构的错误:InvalidTokenError!
解密jwt直接使用jwt-decode即可,非常简单,具体如下:
const jwt_decode = require("jwt-decode")
const auth_header =
"bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VybmFtZSI6Inl1YW5iZXN0IiwiaWF0IjoxNjk1MDkzMjg0fQ.boTiLadv7fG2JpiyCD1_awC0SyQHNpZPOO5zbOhn3Ks";
const output = auth_header.split(" ")[1];
const token2 = jwt_decode(output) //使用jwt_decode解密jwt token
console.log(token2)