广告
返回顶部
首页 > 资讯 > 前端开发 > html >nodejs中的jwt是什么
  • 926
分享到

nodejs中的jwt是什么

2024-04-02 19:04:59 926人浏览 泡泡鱼
摘要

这篇文章主要讲解了“nodejs中的Jwt是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的jwt是什么”吧!

这篇文章主要讲解了“nodejs中的Jwt是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的jwt是什么”吧!

在nodejs中,jwt全称JSON WEB token,是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源。

nodejs中的jwt是什么

教程操作环境:windows7系统、nodejs 12.19.0版,DELL G3电脑。

nodejs中什么是JWT

Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准((RFC 7519).该token被设计为紧凑且安全的,特别适用于分布式站点的单点登录(SSO)场景。

JWT的声明一般被用来在身份提供者和服务提供者间传递被认证的用户身份信息,以便于从资源服务器获取资源,也可以增加一些额外的其它业务逻辑所必须的声明信息,该token也可直接被用于认证,也可被加密。

JWT,在Http通信过程中,进行身份认证。

我们知道HTTP通信是无状态的,因此客户端的请求到了服务端处理完之后是无法返回给原来的客户端。因此需要对访问的客户端进行识别,常用的做法是通过session机制:客户端在服务端登陆成功之后,服务端会生成一个sessionID,返回给客户端,客户端将sessionID保存到cookie中,再次发起请求的时候,携带cookie中的sessionID到服务端,服务端会缓存该session(会话),当客户端请求到来的时候,服务端就知道是哪个用户的请求,并将处理的结果返回给客户端,完成通信。

通过上面的分析,可以知道session存在以下问题:

1、session保存在服务端,当客户访问量增加时,服务端就需要存储大量的session会话,对服务器有很大的考验;

2、当服务端为集群时,用户登陆其中一台服务器,会将session保存到该服务器的内存中,但是当用户的访问到其他服务器时,会无法访问,通常采用缓存一致性技术来保证可以共享,或者采用第三方缓存来保存session,不方便。

Json Web Token是怎么做的?

1、客户端通过用户名和密码登录服务器;

2、服务端对客户端身份进行验证;

3、服务端对该用户生成Token,返回给客户端;

4、客户端将Token保存到本地浏览器,一般保存到cookie中;

5、客户端发起请求,需要携带该Token;

6、服务端收到请求后,首先验证Token,之后返回数据。

服务端不需要保存Token,只需要对Token中携带的信息进行验证即可;

无论客户端访问后台的那台服务器,只要可以通过用户信息的验证即可。

Json Web Token长什么样子呢?

通过名字就可以看出来,是一个json。

由三部分内容组成:

头(header),一般很少改动直接使用默认的即可:

{
 ‘typ’:‘JWT’,
 ‘alg’:‘HS256’
 }

(playload),东西都装在这里,默认的内容有:

{
 ‘iss’:‘签发者’,
 ‘sub’:‘面向的用户’,
 ‘aud’:‘接收方’,
 ‘exp’: 过期时间,
 ‘iat’: 创建时间,
 ‘nbf’: 在什么时间之前,该Token不可用,
 ‘jti’:‘Token唯一标识’
 }

根据需要用户可以自己定义,Token中传输的内容,一般会将用户名,角色等信息放到Token中。

(signature),前面两部分转为字符串后,使用base64编码,然后进行加密得到一个字符串。

Token = header(base64)+ playload(base64)+ signature;

nodejs中的jwt是什么

实现流程

–>用户登录,服务器产生一个token(加密字符串)发送给前端,

–>前端将token保存(想存哪就存哪)

–>前端发起数据请求时携带token

–>服务端验证token是否合法,合法继续操作,不合法终止操作

token的使用场景:无状态请求,保持用户的登录状态,第三方登录(token+auth3.0)

支持算法

alg参数值数字签名或Mac算法
HS256使用SHA-256哈希算法的HMAC
HS384使用SHA-384哈希算法的HMAC
HS512使用SHA-512哈希算法的HMAC
RS256使用SHA-256哈希算法的RSASSA-PKCS1-v1_5
RS384使用SHA-384哈希算法的RSASSA-PKCS1-v1_5
RS512使用SHA-512哈希算法的RSASSA-PKCS1-v1_5
PS256使用SHA-256哈希算法的RSASSA-PSS(仅节点^ 6.12.0 OR> = 8.0.0)
PS384使用SHA-384哈希算法的RSASSA-PSS(仅节点^ 6.12.0 OR> = 8.0.0)
PS512使用SHA-512哈希算法的RSASSA-PSS(仅节点^ 6.12.0 OR> = 8.0.0)
ES256使用P-256曲线和SHA-256哈希算法的ECDSA
ES384使用P-384曲线和SHA-384哈希算法的ECDSA
ES512使用P-521曲线和SHA-512哈希算法的ECDSA
没有不包含数字签名或MAC值

开发时使用

安装

npm install jsonwebtoken --save

使用

const jwt = require('jsonwebtoken');//加载包
//产生token默认算法hs256
let token=jwt.sign({user:'123'},'123114655sad46aa');//此方法接收两个参数,第一个是要加密保存的数据(一个对象,不要放隐秘性的数据,如密码),第二个是要加密的私钥(一个字符串,越乱越好)
console.log(token);//返回一个加密字符串
// 服务器签发的token
//eyJhbGCiOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJ1c2VyIjoiMTIzIiwiaWF0IjoxNTcwMDc2NjU5fQ.3FT6v8zVptdWGBILD1m1CRY6sCP1I3E947krUh_E3



//客户端请求数据的时候验证token
//客户端传递过来的token
let tokens=token;

jwt.verify(tokens,'123114655sad46aa',function (err,data) {
    //verify接收两个参数,第一个参数是客户端传递过来的token,第二个参数是加密时的私钥;第三个参数是回调函数
    console.log(err);//签名通过返回null,签名不通过返回err(JsonWebTokenError: invalid signature)	
    console.log(data);//	通过返回解密数据,失败返回unfinished
});

感谢各位的阅读,以上就是“nodejs中的jwt是什么”的内容了,经过本文的学习后,相信大家对nodejs中的jwt是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: nodejs中的jwt是什么

本文链接: https://www.lsjlt.com/news/87026.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • nodejs中的jwt是什么
    这篇文章主要讲解了“nodejs中的jwt是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“nodejs中的jwt是什么”吧! ...
    99+
    2022-10-19
  • 使用NodeJS实现JWT原理是什么
    这篇文章主要介绍“使用NodeJS实现JWT原理是什么”,在日常操作中,相信很多人在使用NodeJS实现JWT原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”使用No...
    99+
    2022-10-19
  • 浅析nodejs中怎么使用JWT?
    同样点击Send Request当看到下面图片的响应,就意味着响应成功:其实以上就是JWT的一些简单的用法,接下来再说一下JWT本身存在的优缺点.JWT的不足JWT占用的存储空间其实并不小,如果我们需要签名做过多的信息,那么token很可能...
    99+
    2023-05-14
    JWT node
  • nodejs中的express-jwt的使用解读
    目录nodejs中express-jwt的使用nodejs express-jwt is not a function问题总结nodejs中express-jwt的使用 expres...
    99+
    2023-05-16
    nodejs中express-jwt express-jwt的使用 nodejs使用express-jwt
  • nodejs中的gulp是什么
    本文小编为大家详细介绍“nodejs中的gulp是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“nodejs中的gulp是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。gulp是前端开发过程中一种基于流...
    99+
    2023-07-02
  • JWT是什么?Node中怎么实现JWT鉴权机制(浅析)
    【相关教程推荐:nodejs视频教程】一、为什么使用JWT一种技术的出现,就是弥补另一种技术的的缺陷。在JWT出现之前,Session 认证机制需要配合 Cookie 才能实现。由于 Cookie 默认不支持跨域访问,所以,当涉及到前端跨域...
    99+
    2022-11-22
    nodejs​ node
  • nodejs中express是什么
    这篇文章主要介绍nodejs中express是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!                &nbs...
    99+
    2023-06-08
  • 什么是Cookie、Session、Token、JWT
    这篇文章主要介绍“什么是Cookie、Session、Token、JWT”,在日常操作中,相信很多人在什么是Cookie、Session、Token、JWT问题上存在疑惑,小编查阅了各式资料,整理出简单好用...
    99+
    2022-10-19
  • JWT的数据结构是什么
    这篇文章主要介绍“JWT的数据结构是什么”,在日常操作中,相信很多人在JWT的数据结构是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JWT的数据结构是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧...
    99+
    2023-07-04
  • nodejs是什么
    nodejs是什么?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、nodejs简介node 是一个基于 V8 引擎的 Javascript 运行环境,它使得 Javasc...
    99+
    2023-06-14
  • 什么是nodejs
    什么是nodejs,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。nodejs是一个基于Chrome V8引擎的JavaScript运行环境,一...
    99+
    2022-10-19
  • nodejs中的v8引擎是什么
    本篇内容介绍了“nodejs中的v8引擎是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • nodejs中connect的作用是什么
    本篇文章给大家分享的是有关nodejs中connect的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。connect 解析我们要先从...
    99+
    2022-10-19
  • nodejs中lts的概念是什么
    这篇文章主要介绍“nodejs中lts的概念是什么”,在日常操作中,相信很多人在nodejs中lts的概念是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”nodejs中l...
    99+
    2022-10-19
  • 一文了解什么是JWT
    目录起源session认证token认证什么是JWTJWT的数据结构HeaderPayloadSignatureJWT的优点怎么使用JWT总结起源 需要了解一门技术,首先从为什么产生...
    99+
    2023-05-19
    JWT
  • jwt的token机制原理是什么
    JWT(JSON Web Token)是一种用于身份验证和授权的开放标准(RFC 7519),它是一种轻量级的无状态身份验证机制,用...
    99+
    2023-10-07
    jwt
  • Session、JWT与OAuth2的特点是什么
    这篇文章主要讲解了“Session、JWT与OAuth2的特点是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Session、JWT与OAuth2的特点是什么”吧!Session模式浏览...
    99+
    2023-06-26
  • JWT的原理及用法是什么
    本篇内容介绍了“JWT的原理及用法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、跨域认证的问题互联网服务离不开用户认证。一般流程是...
    99+
    2023-07-04
  • 什么是JWT?深入理解JWT从原理到应用
    🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给...
    99+
    2023-10-08
    jwt jjwt-root session
  • nodejs的作用是什么
    nodejs的作用是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、nodejs简介node 是一个基于 V8 引擎的 Javascript 运行环境,它...
    99+
    2023-06-14
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作