在express中生成token

一、安装第三方包

npm install jsonwebtoken

二、导入

const jwt = require('jsonwebtoken');

三、使用
生成token

let content ={name:req.body.name};
 // 要生成token的主题信息,可以是用户的id、用户名等唯一的标识名,
 //也可以是数据库自己的id(一般使用数据库自己的id即可),但不可以是用户的密码,
 //类型可以是对象或字符串
let secret="syyyuigfrhygfgi" 
// 这是加密的key(密钥),可以是任意的内容,但在开发中一般不写在代码中,而是一个文件
let token = jwt.sign(content, secret, {
expiresIn: 60*60*1  // 1小时过期
});
//调用jwt.sign方法生成token,前两个参数必传,第三个参数可不传
//生成token后,将token放在要发给客户端的json格式的数据里面,
//前端就可以获得token并存入localStorage了(在服务端也可以将token存到数据库里)

验证token

let token = req.body.token
//获取前端发过来的token,如果没有token就返回需要登录的提示信息
jwt.verify(token, secret, function (err, decode) {
                if (err) {  //  时间失效的时候或者伪造的token          
                    res.send({'status':0});            
                } else {
                    res.send({'status':1});
                }
            })
//前两个参数必传,第三个参数可不传,
//token为前端发过来的token,secret为之前自定义的密钥
//jwt.verify()的返回值为对象或字符串,
//jwt.sign()第一个参数是什么类型就返回什么类型,包含之前加密了的值,相当于解密,
//可以将jwt.verify()的返回值打印出来看看
//最后就可以根据jwt.verify()的返回值做相应的处理了
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Express ,使用 JSON Web Token (JWT) 生成和验证 token。下面是一个简单的示例: 首先,安装 jsonwebtoken 模块: ``` npm install jsonwebtoken ``` 然后,在需要生成 token 的地方引入模块: ```javascript const jwt = require('jsonwebtoken'); ``` 接下来,创建一个路由,用于生成 token: ```javascript app.post('/login', (req, res) => { // 在这里验证用户的用户名和密码 const username = req.body.username; const password = req.body.password; // 如果验证通过,则生成 token const token = jwt.sign({ username }, 'secret key', { expiresIn: '1h' }); // 将 token 返回给客户端 res.json({ token }); }); ``` 在上面的示例,使用 `jwt.sign()` 方法生成 token。第一个参数是一个对象,用于存储需要在 token 保存的数据。第二个参数是一个字符串,用于指定加密的密钥。第三个参数是一个选项对象,用于设置 token 的过期时间。 最后,客户端在需要访问受保护的路由时,需要在请求头传递 token: ```javascript axios.get('/protected', { headers: { Authorization: `Bearer ${token}` } }); ``` 在服务器端,可以使用 `jwt.verify()` 方法验证 token: ```javascript app.get('/protected', (req, res) => { const token = req.headers.authorization.split(' ')[1]; try { const decoded = jwt.verify(token, 'secret key'); console.log(decoded); // { username: 'xxx', iat: xxx, exp: xxx } // 在这里处理受保护的请求 res.json({ message: 'Access granted' }); } catch (err) { res.status(401).json({ message: 'Invalid token' }); } }); ``` 在上面的示例,使用 `jwt.verify()` 方法验证 token,并且从 token 解码出存储的数据。如果验证通过,则处理受保护的请求,否则返回 401 错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值