Ruoyi-vue-plus5.0登录流程详解

 项目网站:RuoYi-Vue-Plus: 后台管理系统 重写RuoYi-Vue所有功能 集成 Sa-Token、Mybatis-Plus、Jackson、SpringDoc、Hutool、OSS 定期同步 - Gitee.com

一、前端部分

这里两个文件对应两种环境。

这里我们可以看到对encrypt-key这个密匙是进行了两次加密,一次Base64一次RSA加密后续后端也会解密两次。

二、后端部分

请求经过crypto过滤器检测到存在加密标头,然后转到解密类中解密


先获取header中的密匙解密两次后解密请求体中的参数

 

 这里的配置对应拦截器中的参数

进入controller层首先校验授权类型是否存在于客户端授权类型有:

一个客户端可以有多种授权类型,只要满足其中一个即可。
进入login方法

根据传入的授权类型获取容器中对应的bean对象来区分调用哪一个实现类中的login方法。

我们看到这个类中有多个实现类对应着每个授权类型。这里我们是密码登录所以进入PasswordAuthStrategy。

成功返回即登录成功。

三、安全校验

值得一提的是将clientId传入token中后续的校验,看下图:

这个拦截器会拦截除登录相关接口的所以请求,处理检查是否有token外,还会校验请求请求header中的客户端id、参数中的客户端id、token中客户端的id只需要其中两个一致即可通过拦截器否则会被拦截

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值