Sangfor华东天勇战队:jeecg-boot登录分析

news2025/1/2 0:24:31

realkey获取

7evs1680077379806
在这里插入图片描述
可以看到代码逻辑如下,md5(小写验证码+checkKey),这里checkKey是时间戳
在这里插入图片描述
然后继续往下看
在这里插入图片描述
这里checkcode取值为空,这是为什么呢,是因为redisUtil中没有获得,登录的时候会存到redis中,不可能获得不了,是因为超过了60s,redis中自动清除了key,那么这也就限制了登录的时间,一定程度防止了中间人攻击
那么我们快速操作一次
在这里插入图片描述
可以看到if语句checkCode.toString().equals(lowerCaseCaptcha条件相等,因此绕过了if语句执行以下的语句

密码加密

继续看看密码加密部分
在这里插入图片描述
进入encrypt()方法看看,这里传入三个参数plaintext,password,salt分别为用户名,密码,盐值
在这里插入图片描述
通过getPBEKey()得到key值,通过PBEWithMD5AndDES算法进行加密,最终返回十六进制字符串[-53, 54, 44, -2, -17, -65, 61, -115]
在这里插入图片描述
syspassword和userpassword进行对比,可以看到密码校验成功,绕过if继续下面的获得用户信息
这里明显就是用户登录框输入账号密码,然后进行加密,与mysql数据库中的值进行比对

这里引起我的疑问,就是数据是怎么从数据库中拿到的
在这里插入图片描述
用到了lambda特性,从SysUser获得getUsername,那么跟踪SysUser
在这里插入图片描述
来自于queryWrapper,那么queryWrapper来自LambdaQueryWrapper<>()类,
在这里插入图片描述
那么就跟到了mybatis-plus中了
那么这一块就是通过封装好的查询类queryWrapper进行查询的,先是通过eq进行用户名判断,然后.getOne()返回出这一条关于admin的数据
在这里插入图片描述
可以看到这样就获得了数据库中的admin数据,也就获得了admin的password为cb362cfeefbf3d8d
加密方式,可以看到
在这里插入图片描述
在这里插入图片描述
这种加密方式具体算法我们不清楚,但是加密方法PasswordUtil.encrypt传入了三个参数用户名,密码,盐值,用户名密码都是登录处获得的,盐值是从数据库中拿到的,
那么盐值是怎么生成的呢,那我们不由自主的想到了注册

那么先不看salt怎么生成,我们先看token怎么生成的
进入Userinfo()
继续往下走
在这里插入图片描述
在这里插入图片描述
利用Jwt生成token常用的代码块, 网上一搜一大堆
接下来设置redis中的token缓存时间
在这里插入图片描述
密码加密方式

PasswordUtil passwordUtil = new PasswordUtil();
String userpassword = passwordUtil.encrypt("admin", "123456", "RCGTeGiH");
System.out.println(userpassword);

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/686080.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SLAM之反求运动和地图点(对极几何)

简介 前面的文章介绍了如何在已知空间点的情况下在不同坐标系中的表示&#xff08;刚体的坐标变换&#xff09;&#xff0c;以及如何将空间中的点投影到相机中生成图像&#xff0c;但是现实中的情况却是相反的情况&#xff08;空间点以及坐标系之间的变换未知&#xff09;&…

【裸机开发】定时器按键消抖(EPIT)

实际工程中&#xff0c;不能直接通过延时来消抖 ! 这里我们采用定时器来消抖&#xff0c;这也是内核处理消抖的一种方式。 目录 一、基本原理 1、延时消抖的弊端 2、定时器消抖原理 二、按键消抖实现 1、按键中断 2、定时器中断 三、附加&#xff1a;按键 / 定时器中断初…

前后端分离开发跨域问题总结

前后端分离开发跨域问题总结 一、什么是跨域访问二、解决跨域问题1、Vue前端配置代理解决跨域2、SpringBoot后端配置解决跨域2.1 跨域配置类CorsConfig&#xff08;常用&#xff09;2.2 Controller添加CrossOrigin注解2.3 添加CORS过滤器CorsFilter&#xff08;常用&#xff09…

selenium之鼠标操作

首先导入ActionChains类&#xff0c;该类可以完成鼠标移动&#xff0c;鼠标点击事件&#xff0c;键盘输入、内容菜单交互等交互行为。 from selenium.webdriver.common.action_chains import ActionChains 操作语法&#xff1a; 第一步&#xff1a;初始化ActionChains类&…

系列二、Maven下载安装配置

一、下载 链接&#xff1a;https://pan.baidu.com/s/1BvwLzAk9kRSP-daxSYe4Vw?pwdyyds 提取码&#xff1a;yyds 二、安装 第一步&#xff1a;下载安装包 第二步&#xff1a;解压至安装目录&#xff0c;例如 第三步&#xff1a;配置settings.xml&#xff08;主要配置maven本…

Open ai 开发指南:gpt接口的第一个问答机器人demo

目录 内容 Python代码 C 代码 workspace 文件 BUILD文件 Java 代码 maven文件 执行效果 内容 基于openai接口实现循环gpt问答&#xff0c;并使用一个文件将问答内容进行记录。 Python代码 # -*- coding: utf-8 -*- import openai import time from pathlib import P…

100天精通Python(可视化篇)——第93天:Pyecharts绘制多种炫酷饼图参数说明+代码实战(百分比、环形、玫瑰、内嵌、多个子图饼图)

文章目录 专栏导读1. 基础饼图add函数简单案例改变颜色 2. 百分比饼图3. 环形饼图4. 玫瑰饼图5. 内嵌环图6. 多个饼图 专栏导读 &#x1f525;&#x1f525;本文已收录于《100天精通Python从入门到就业》&#xff1a;本专栏专门针对零基础和需要进阶提升的同学所准备的一套完整…

学习前端开发,能抛弃HTML和CSS吗?

前言 前端开发里面HTML和CSS是两个非常重要的核心技术&#xff0c;它们是构建网页和应用程序界面的基础。 HTML&#xff08;超文本标记语言&#xff09;是用于描述网页结构的标记语言&#xff0c;它定义了网页的内容、布局和元素。几乎所有的网页都使用HTML来组织和呈现内容&…

5.6.3 套接字

5.6.3 套接字 我们先以示例引入套接字的基本内容&#xff0c;我们知道在邮政通信的时候我们需要在信封上写明我们的收件地址&#xff0c;比如北京市海淀区双清路30号清华大学8444号某某某收&#xff0c;这其中我们需要一个物理地址“北京市海淀区双清路30号”&#xff0c;一个…

SpringBoot 如何使用 Ehcache 作为缓存?

SpringBoot 如何使用 Ehcache 作为缓存&#xff1f; 在现代的应用程序中&#xff0c;缓存是一个非常重要的概念。缓存可以帮助我们加速应用程序的响应时间&#xff0c;减少数据库或其他服务的负载&#xff0c;并提高系统的可扩展性和容错性。Spring Framework 提供了强大的缓存…

Linux下的su指令和last指令

文章目录 1 切换用户命令&#xff08;su&#xff09;2 查看本机的所有登录记录&#xff08;last&#xff09;3 退出当前登录账户&#xff08;exit&#xff09; 1 切换用户命令&#xff08;su&#xff09; su 命令可以切换成不同的用户身份&#xff0c;命令格式如下&#xff1a…

【文本SR:轻量级:残差注意力】

A Lightweight Deep Residual Attention Network for Single Image Super Resolution &#xff08;一种用于单幅图像超分辨率的轻量级深度残差注意力网络&#xff09; 本文将稀疏编码技术应用于基于学习的文本图像超分辨率&#xff08;SR&#xff09;中&#xff0c;以提高光学…

浅析做好数据安全风险评估的重要性

一、被忽略的数据安全风险 快速问答 你知道公司内有多少数据资产吗&#xff1f; 这些数据资产中哪些数据更为重要&#xff1f; 如何保护公司数据资产&#xff0c;防止数据泄露&劫持等事件发生&#xff1f; 如果你一问三不知的话&#xff0c;也许你该好好思考数据安全这项…

数据库系统概论(三)数据库设计、数据库恢复技术、并发控制

作者的话 前言&#xff1a;总结下知识点&#xff0c;自己偶尔看一看。 一、数据库设计 数据库设计是指对于一个给定的应用环境&#xff0c;构造&#xff08;设计&#xff09;优化的数据库逻辑模式和物理结构&#xff0c;并据此建立数据库及其应用系统 1.1概述 1.1.1数据库设计…

mysql 简单定位慢查询并分析SQL执行效率

实际的日常开发工作中可能会遇到某个新功能在测试时需要很久才返回结果&#xff0c;这时就应该分析是不是慢查询导致的&#xff0c;如果确实有慢查询&#xff0c;就需要来学习怎么找到慢查询和怎么分析 SQL 执行效率&#xff1f; 定位慢 SQL 有如下两种解决方案&#xff1a; …

ClickHouse-简单了解

文章目录 前言数据库引擎数据表引擎Log 系列Integration 系列Special 系列MergeTree 系列 ClickHouse 数据类型ClickHouse 常用的函数 前言 什么是 ClickHouse&#xff1f;简单来说它是一个高性能&#xff0c;面向列的SQL数据库管理系统&#xff08;DBMS&#xff09;&#xff…

嵌入式知识分享——GDB程序调试方法说明

前 言 本指导文档适用开发环境&#xff1a; Windows开发环境&#xff1a;Windows 7 64bit、Windows 10 64bit Linux开发环境&#xff1a;Ubuntu 18.04.4 64bit 虚拟机&#xff1a;VMware15.1.0 U-Boot&#xff1a;U-Boot-2020.04 Kernel&#xff1a;Linux-5.4.70 Linux…

接口调用重放测试-业务安全测试实操(21)

接口调用重放测试。 接口调用遍历测试 接口调用重放测试 测试原理和方法 在短信、邮件调用业务或生成业务数据环节中,如短信验证码、邮件验证码、订单生成、评论提交等,对业务环节进行调用(重放) 测试。如果业务经过调用(重放) 后多次生成有效的业务或数据结果,可判断为存在…

PMP®证书增持 CSPM-2证书,哪里办理?

2023年6月起&#xff0c;持有PMP证书的朋友可以直接增持一个同等级证书CSPM-2&#xff0c;不用重新考试&#xff0c;不用重新学习&#xff0c;原PMP证书不影响正常使用&#xff0c;相当于多了一个国标项目管理领域的证书。 第一步准备资料 1、填写能力评价表 2、提供2张2寸蓝底…

在 Jetson Nano 上安装 ncnn 深度学习框架。

Install ncnn deep learning framework on a Jetson Nano. Introduction.RTTI.CMake 3.18.4.Dependencies.Benchmark.Introduction. 本页面将指导您在 Jetson Nano 上安装腾讯的 ncnn 框架。由于 ncnn 框架面向移动设备(例如 Android 手机),因此它不支持 CUDA。然而,大多数…