nodejs中的express-jwt的使用解读
更新时间:2023年04月20日 10:19:45 作者:初上秋名山
这篇文章主要介绍了nodejs中的express-jwt的使用解读,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
nodejs中express-jwt的使用
express-jwt更新到7.x版本后更改了用法,无法像7.x版本之前那样使用express—jwt,导入、在中间件配置个密钥就行了,更新之后,需要在express-jwt中将其解构出来再使用。
也无法在排除的路径中使用req.user去获取用户token解密出来的数据。而是使用req.auth。
具体代码如下:
const express = require('express') const app = express() const jwt = require("jsonwebtoken") // 导入jwt const {expressjwt} = require("express-jwt") //从express-jwt中解构 const port = 3000 const secretKEY = "lam12138" //密钥 app.use(expressjwt({ secret:secretKEY, algorithms: ["HS256"] }).unless({path: ["/api/login"] })) //使用express-jwt这个中间件 排除路径为api/login app.post("/api/login",(req,res)=>{ // 获得token const token = jwt.sign({username :"lam"},secretKEY,{expiresIn:"60s"}) res.send({ status:200, msg:"success", token }) }) app.get( "/protected", function (req, res) { // 即可在非排除路径下获得解密后的用户信息 通过req.auth 获取。相当于 express—jwt 6.X版本下的req.user console.log(req.auth) res.send("+-+") } ); // 捕获错误的路由需要放在所有路由的后面 app.use((err, req, res, next)=> { if(err.name == "UnauthorizedError"){ res.status(401).send("无效的token..."); }else { next(err); } }); app.listen(port, () => console.log(`Example app listening on port http://127.0.0.1:${port}!`))
nodejs express-jwt is not a function问题
原:
const expJWT = require("express-jwt");
改之后:
const {expressjwt:jwt} = require("express-jwt"); const keys=require("./config/index") app.use(jwt({ secret: keys.secretKey, algorithms: ['HS256'] }).unless({ path: [/^\/login\//] }));
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Node.js node-schedule定时任务隔多少分钟执行一次的方法
这篇文章主要介绍了Node.js node-schedule定时任务隔多少分钟执行一次的方法,本文给出了每隔 15 分钟、 30 分钟执行一次任务的编码实例,需要的朋友可以参考下2015-02-02node.js基于dgram数据报模块创建UDP服务器和客户端操作示例
这篇文章主要介绍了node.js基于dgram数据报模块创建UDP服务器和客户端操作,结合实例形式分析了node.js使用dgram数据报模块创建UDP服务器和客户端,以及进行UDP广播、组播相关操作技巧,需要的朋友可以参考下2020-02-02windows系统上完全卸载并重装Node的步骤(亲测可用)
对于Windows平台来说,所有的应用程序,其安装卸载都是一样的,node.js也不例外,但是还是很多用户不明白,下面这篇文章主要给大家介绍了关于windows系统上完全卸载并重装Node的步骤,需要的朋友可以参考下2023-03-03
最新评论