欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 社会 > Node.js 使用 Express-Jwt和JsonWebToken 进行Token身份验证

Node.js 使用 Express-Jwt和JsonWebToken 进行Token身份验证

2025/5/6 13:24:58 来源:https://blog.csdn.net/2302_79169315/article/details/141302803  浏览:    关键词:Node.js 使用 Express-Jwt和JsonWebToken 进行Token身份验证

前言

本文将实现在Node.js中使用Express-Jwt和JsonWebToken进行身份验证

代码

假设一个这样的用户登录场景,用户在成功登录之后,前端会向后端请求用户信息,并将用户信息渲染到页面上。

不使用token
web
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- 引入axios --><script src="https://cdn.staticfile.net/axios/1.6.5/axios.js" crossorigin="anonymous"></script><span>用户信息</span><button>获取用户名</button><script>document.querySelector('button').onclick = function(){axios.get('http:///127.0.0.1/getName').then(function(response){console.log(response);document.querySelector('span').innerHTML = response.data},function(err){console.log(err);})}</script>
</body>
</html>

这是一段非常简单的代码,点击按钮向后端请求用户信息,并将其渲染到页面上

server
/* 导入第三方库 */const express = require('express')const cors = require('cors')//解决跨域问题/* 创建实例 */const user = {username: 'qiuchuang',password: 123456}const app = express()const router = express.Router()/* 路由处理函数 */router.get('/getName',(req,res)=>{res.send(user.username)
})/* 注册中间件 */app.use(cors())
app.use(router)/* 注册根路由 */app.use('/', (req, res) => {res.send('ok')})/* 启动服务器 */
app.listen('80', () => {console.log('server is running at http://127.0.0.1');
})

这是后端代码,创建了一个router路由处理函数,响应前端请求,有一定基础的读者看起来应该不难理解

接下来,我们将代码升级一下,前端不能再直接从服务器中请求数据,而需要使用token认证才能获取到用户信息

使用token

web
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- 引入axios --><script src="https://cdn.staticfile.net/axios/1.6.5/axios.js" crossorigin="anonymous"></script><span>用户信息</span><button>获取用户名</button><script>window.onload = function(){axios.get('http://127.0.0.1/getToken').then(function(response){console.log(response);},function(err){console.log(err);})}document.querySelector('button').onclick = function(){axios.get('http://127.0.0.1/getName',{headers:{'Authorization':`${localStorage.getItem('userToken')}`}}).then(function(response){console.log(response);document.querySelector('span').innerHTML = response.data},function(err){console.log(err);})}</script>
</body>
</html>

这段前端代码不难理解,简单解释一下就是在页面加载的时候向服务器端请求token,该token中包含了用户基本信息,待页面加载完成后,点击按钮,可以向服务器端请求用户信息,并将用户信息渲染到页面上。

值得注意的是,在请求用户信息的时候,必须在请求头中包含服务器发送的token才能有权限获取用户信息

后端代码

重点讲讲后端代码

/* 导入第三方库 */const express = require('express')const cors = require('cors')//解决跨域问题const jwt = require('jsonwebtoken')//生成tokenconst expressJwt = require('express-jwt')//验证tokne/* 创建实例 */const app = express()const router = express.Router()const user = {username: 'qiuchuang',password: 123456}const config = {jwtScrectKey: 'qiuchuang No1 ^-^',//加密密钥expiresIn: '10h'//有效时间}router.get('/getToken', (req, res) => {/*生成token */const token = jwt.sign(user,config.jwtScrectKey,{expiresIn:config.expiresIn})//将token信息挂在到user对象中res.send(token)})router.get('/getName',(req,res)=>{res.send(req.user.username)
})/* 注册中间件 */app.use(cors())app.use(expressJwt({secret:config.jwtScrectKey}))app.use(router)/* 注册根路由 */app.use('/', (req, res) => {res.send('ok')})/* 捕获全局错误的中间件 */app.use((err, req, res, next) => {if (err.name === 'UnauthorizedError') {return res.send('身份认证失败')}res.send(err)})app.listen('80', () => {console.log('server is running at http://127.0.0.1');
})

让我们看看增添了哪些代码,

1.导入token相关的模块
const jwt = require('jsonwebtoken')//生成tokenconst expressJwt = require('express-jwt')//验证tokne
2.配置对象
const config = {jwtScrectKey: 'qiuchuang No1 ^-^',//加密密钥expiresIn: '10h'//有效时间}
3.响应token的路由处理函数
router.get('/getToken', (req, res) => {/*生成token */const token = jwt.sign(user,config.jwtScrectKey,{expiresIn:config.expiresIn})//将token信息挂在到user对象中res.send(token)})
4.注册验证token的中间件
app.use(expressJwt({secret:config.jwtScrectKey}))
5.处理错误的中间件
/* 捕获全局错误的中间件 */app.use((err, req, res, next) => {if (err.name === 'UnauthorizedError') {return res.send('身份认证失败')}res.send(err)})
6.一处改动
res.send(user.username)

改为

res.send(req.user.username)

由于将token信息挂载到了user对象上,req多出了一个user属性,使用这个user属性可以根据客户端发送的token而解析出对应的信息,也就实现了我们的目的-----用token进行身份认证

对比两处代码,相信读者可以比较好地知道怎么实现基本的token身份认证,后续的代码升级读者也可以以此为基本,实现高级的功能。

OK,今天的分享就到这里,我是秋窗,我们下期再见👋

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词