Node登录权限验证token验证实现

Node登录权限验证token验证的原理和实现

1. token的使用场景

  1. 无状态请求
  2. 保持用户的登录状态
  3. 第三方登录(token+auth2.0)

2. 基于token的验证原理

后端不再存储认证信息,而是在用户登录的时候生成一个token,然后返回给前端,前端进行存储,在需要进行验证的时候将token一并发送到后端,后端进行验证

加密的方式:对称加密和非对称加密,对称加密指的是加密解密使用同一个密钥,非对称加密使用公钥和私钥,加密用私钥加密,解密用公钥解密

3. 基于Token的身份验证的过程如下:

客户端:用户名和密码请求登录

服务器:收到请求,验证用户名和密码,验证成功后,分发一个Token返回给客户端

客户端:将Token存储,例如放在 Cookie 里或者 Local Storage 里,后续每次请求,带上此Token

服务器:收到请求,验证Token是否正确,验证成功返回请求数据

4. node + jwt(jsonwebtoken) 搭建token身份验证

  1. 安装 ActivePerl https://www.activestate.com/activeperl/downloads
  2. 安装 OpenSSl http://slproweb.com/products/Win32OpenSSL.html
  3. 在 ras 文件 终端夹下输入 openssl
  4. 生成私钥
openssl> genrsa -out ./private_key.pem 1024 
  1. 生成公钥
openssl> rsa -in ./private_key.pem -pubout -out ./public_key.pem
  1. 下载包 jsonwebtoken
npm i jsonwebtoken -D                 // 安装jsonwebtoken模块
const jwt = require('jsonwebtoken'); //引入包
  1. 通过私钥生成 token,发送给前端
let private_key=fs.readFileSync(path.join(__dirname,'./private_key.pem'))
var token = jwt.sign(palyload, private_key,{ algorithm: 'RS256'});
  1. 后端接收 token 验证是否有 token,没有则生成

  2. 前端把 token 存再 localStorage 或者 cookie 里

$.ajax({
   
     url:'http://localhost:3000/login',
     data: {
   
       username:username.value,
       password:password.value
  • 5
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值