express根据token获取用户id「建议收藏」

//登陆时注册tokendb.query(`select*fromuserwherename=${username}andpassword=’${password}’`,(result)=>{if(result.length==1){ //jwt.sign({userId:result[0].id}在注册的时候加入用户id…

大家好,又见面了,我是你们的朋友全栈君。

//登陆时注册token
db.query(`select * from user where name=${ 
     username} and password='${ 
     password}'`, (result) => { 
   
    if (result.length == 1) { 
   
    	//jwt.sign({userId:result[0].id} 在注册的时候加入用户id
        const token = jwt.sign({ 
   userId:result[0].id}, 'buddha', { 
   
            expiresIn: 60 * 60 * 24// 授权时效24小时
        });
        jwt.verify(token, 'suiyi', function(err, decoded) { 
   
            let accessToken=decoded;
            accessToken.token=token;
            accessToken.id=result[0].id;
            accessToken.name=result[0].name;
            res.send({ 
   
                "status": "success",
                "data": [accessToken]
            });
        });
    } else { 
   
        return next(createError(400, '账号或密码错误'));
    }
})

创建一个检查是否登录的中间件,此时就会看到用户id


var createError = require('http-errors');
var jwt = require('jsonwebtoken')
module.exports =(req, res, next)=>{ 
   
    // 拿取token 数据 按照自己传递方式写
    var token = req.body.token || req.query.token || req.headers['token'];

    if (token) { 
   
        // 解码 token (验证 secret 和检查有效期(exp))
        jwt.verify(token, 'suiyi', function(err, decoded) { 
   
            if (err) { 
   
                return res.status(400).send(next(createError(400, '无效的token')));
            } else { 
   
                // 如果验证通过,在req中写入解密结果
                console.log(decoded)//{ userId: 31, iat: 1574244315, exp: 1574330715 }
                req.decoded = decoded;
                next();
            }
        });
    } else { 
   
        return res.status(403).send(next(createError(403, '没有找到token')));
    }
};

最后 req.decoded.userId即可获取用户id

exports.collect_article = async (req, res, next) => { 
   
    
    console.log(req.decoded.userId)

}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/129561.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 现代语音信号处理笔记 (一)

    现代语音信号处理笔记 (一)本系列笔记对胡航老师的现代语音信号处理这本书的语音处理部分进行总结,包含语音信号处理基础、语音信号分析、语音编码三部分。一开始以为三部分总结到一篇文章里就可以了,但写着写着发现事情并没有那么简单。。。因此还是老老实实的总结吧,扎实的基础最重要。语音信号处理基础语音信号的处理简称语音处理,是用数字信号处理技术对语音信号进行处理的一门学科。语音信号均采用数字方式进行处理,语音信号的数字…

    2022年5月26日
    43
  • vscode 字体太小的问题,安装新字体

    vscode 字体太小的问题,安装新字体vscode 很好用 但是字体太小了 尤其是 linux 版本 字都拥挤在一起 1 左侧字体小 可以 ctrlshift 或者 ctrlshift 来控制界面整体缩放 2 右侧字体太小 可以安装新的字体 Fira Code v5 22 1 下载链接 FiraCode 为写程序而生的字体 简书 2 2windows 安装字体在 ttf 文件上逐个双击 打开字体管理器 点安装 2 3linux 安装字体 mkdir p usr share fo

    2025年10月29日
    2
  • Lichee(三) Android4.0该产品的目标文件夹,Lichee链接—extract-bsp

    Lichee(三) Android4.0该产品的目标文件夹,Lichee链接—extract-bsp

    2022年1月6日
    50
  • hostapd配置

    hostapd配置我们有个闲置的USB无线适配器(WIFI适配器),而我们的ISP路由器却是有线的。怎样把我们的家庭NAS服务器变成无线访问点(WAP),在不用买额外的WPA盒子的情况下,在Debian或Ubuntu系统下使用无线设备访问到它?你需要使用hostapd作为访问点和认证服务器。它实现了IEEE802.11访问点管理,IEEE802.1X/WPA/WPA2/EAP授权,RADIUS客户端,…

    2022年5月21日
    220
  • JMS activeMQ

    JMS activeMQ

    2022年3月3日
    37
  • 异步fifo的工作原理_netty的异步实现原理

    异步fifo的工作原理_netty的异步实现原理FPGA(一):异步FIFO实现(包含源码和仿真文件)一、异步FIFO的重要参数及其作用1、FIFO:FirstInputFirstOutput,即先入先出队列,本质是RAM。FIFO有几个最重要的参数:2、wr_clk:写时钟,所有与写有关的操作都是基于写时钟;3、rd_clk:读时钟,所有与读有关的操作都是基于读时钟;4、FIFO_WIDTH:FIFO的位宽,即FIFO中每个地址对应的数据的位宽;5、FIFO_DEPTH:FIFO的深度,即FIFO中能存入多少个(位宽为FIFO_

    2022年8月13日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号