瑞数 4 逆向 js 分析过程

2023-10-25 16:10
文章标签 分析 js 过程 逆向 瑞数

本文主要是介绍瑞数 4 逆向 js 分析过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、rs4/5特点

① 服务器响应状态码202或者412返回第一个cookie_s;然后js混淆生成了第二个cookie_t,只有携带有效的cookie_t才能正确请求页面状态码才是200

 ② 如何区分是几代版本,看cookie_t的第一个数字,绝大多数通过该数字就可以确定是几代,如图片中样例是4代

 ③ cookie_t大致有两种:FSSBBIl1UgzbN7N80T,FSSBBIl1UgzbN7N443T,其区别含义443(https)、80(http)其实是服务器的端口号

④ 加载vm的1万多行代码入口特性用正则匹配是:ret=\S{4}.call(\S{4},(\S{4}));

 ⑤ 5代和4代的核心加密逻辑差不多,抠出4代,5代也没问题;唯一有问题的在于128位数组里面有些的逻辑需要细细研究;加载vm的1万多行代码入口特性有3种,如图4代、旧版5代、新版5代

二、网站请求流程

1、第一次请求:假设请求urlA返回状态码202,与响应cookie_SFSSBBIl1UgzbN7N80S;响应源码只有光秃秃的内容,大致分为三部分见图说明,目前看到的这些js逻辑先了解下,重要的记住是:

 ① 主流程自执行函数会生成一个全局变量$_ts,同时将外链js混淆文件还原成在vm里的1完多行的代码

② vm里1万多行的代码与主流程自执行函数里面之间的交互关系,主要依赖于$_ts变量作为媒婆中间人传递的;

③ meta里的content内容也是在vm里万行多行代码里面需要使用到

2、第二次请求:只携带cookie_S请求了外链js文件,之后js生成了cookie_T,响应状态码200,此次学习需要关注的地方就是cookie_T,此处cookie_T是FSSBBIl1UgzbN7N80

 3、第三次请求:携带cookie_S与cookie_T再次请求urlA, 返回状态码200

 4、之后当你打开谷歌开发者工具,就会自动debugger住,这是遇到该类网站看到的流程差不多就是这样,此时已处于加载完的状态,过无限debugger我们这里选择鼠标右击序号然后选择Never pause here即可过无限debugger了

 三、网站加载js的顺序

1、首先监听script断点,然后并清除浏览器缓存,再然后刷新网页,不停的下一步直到看到图下的js停下,这是第一步加载了外链的js文件代码,并赋给了$_ts对象

 2、继续往下调试,跳到如图下,这是第二步,执行一段js,我们称之为主流程自执行函数;它主要做了两件事,一件是将外链的js代码乱码还原成VM里的一万多行的代码,另一件则是给全局变量window.$_ts赋了很多属性变量;

 3、搜索call,找到了VM代码的入口,此时外链的js内容被解密成VM的一万多行代码,即这里的_$KF;通过eval加载_$KF,即可进入第三步,

 4、第三步则看到了VM的一万多行的代码。VM代码的主要作用就是生成cookie(加载动态的content以及动态的$_ts来生成),差不多就是这么个顺序

 四、 固定文件

1、固定 第一次 202 html 和 js 文件以便在扣代码时代码变量名等不会动态变化

五、Hook cooki

 六、过无限 debugger

1、直接右键 Never pause here 永不在此处断下即可

7、正式开始扣代码(提示:这里指演示过程中的主要流程一些单独参数不做详细说明了太多了 )

1、Hook 到了第一次 假 cookie 生成的地方, 又用真 cookie 会用到

 2、_$Ve 第一次 cookie 最终展示的函数

 3、来我们在往下追一层发现第一次加密 cookie 是 _$gs(5) 生成的,我们接着 _$gs(5) 函数走

 4、进入_$gs(5) 函数

5、 进入 _$xx(_$BZ(_$yl)) 的 _$BZ(_$yl)

 6、进入 _$BZ(_$yl) --> _$BZ = _$2j --> 中间穿插了 _$mi(_$OJ) 函数

 7、进入 _$xx(_$yl)

 8、进入 _$5S(_$yl)

 9、进入 _$Xk(_$yl)

 10、进入 _$uF(_$yl)

 11、进入 _$U9(_$yl, _$my)

 12、进入 _$4R(_$yl)

 13、进入_ $PS(_$yl, _$my, _$$e)

最终返回:4a.ly.ENOlWUQEpRvYwgM4e7p4kR6DFVetLXQWRZQmis869tC2iU9SI2BAusUOnJg09u4FvrvYkdER_TU.ADQAQmvg7X5ghB49cOrci.N4IyO92xu7G6WxIT1clZqjQMsqOL.gR7f93OV8O8p_9McMJ8XyEul1C3wK0sinOIqZBAPDk7IQX9aU7kxvEkLHIC8GivY4z8tXeHihAuP5fYSqVe2

 14、真 cookie 开始处

 15、咱们开始求_&OJ 生成处 现在非常主要就是求出 这三个参数了

 16、咱们从 _$P5 开始

16.1 : 第一层

 16.2:第二层 上层的 _$P5 就是这个循环得出,而我们也看见这个循环由 _$OJ 和 _$YJ 两个数组组成

 16.3:第三层 我们先追 _$OJ 这个 OK 很好 我们又要追 _$yl

 16.4:第四层 _$yl 哈拉少 到这里 _$yl = _$OJ , _$OJ就出来了当然里面在涉及到 _$hn 和 _$Fe 我就不往下追了只能告诉各位涉及的代码量还相当大细心点往下追就行

 16.5:第四层 我们开始追 _$YJ 哇哈哈 到这里 _$YJ 就出来了 当然往下追_$Fe 和 _$rq 函数下还有相当大的量我搞过了太多实在再不想往下追了你们自行追吧,那到这里我们是不是 _$P5 参数就出来了哈 图一 再给你回忆下哈

图一:

图二:

 17、挖挖挖 咱们继续追 关键的第二个参数 _$XK | 哈哈 又和 _$P5 _$YJ 干上了 但这里的只能说属于一个系统的不同的阶段

 17.1、继续干吧!先来 $P5 来来来 继续干 _$YJ

 17.2、 _$YJ 来吧 $P5 完毕!!! 还是那句话再往下自己追吧!我是追吐了

 17.3、 正牌 _$YJ 开始, OK _$YJ 也出来了 还是那句话下面这三个参数量依旧很大你们自己往下追 嘿嘿嘿黑 奸笑自此:_$XK 我们的第二个最重要的参数出来了 (顺带说句开头我们说到的假cookie啥的参数在你们继续往下追时都会遇到,不限于这个 17.3 一个)

 18、凑凑凑 来继续干第三个 _$qU 完事 哈哈 挺糊弄 往下追就逗你们自己追吧!我是看吐了不想再弄了

 19、自此三个关键参数全部完毕,接下来让我们看看最终结果吧,两次执行结果

  

声明:(由于大标题1-3内容大家也都带清楚,所以我这引用写的比较好的作者:十一姐 微信公众号:逆向OneByOne ,另外公众号:K哥爬虫 人均瑞数系列 写的也不错的,我也是参考了这两位大神的文章做的)

这篇关于瑞数 4 逆向 js 分析过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/283677

相关文章

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性

SpringBoot整合Sa-Token实现RBAC权限模型的过程解析

《SpringBoot整合Sa-Token实现RBAC权限模型的过程解析》:本文主要介绍SpringBoot整合Sa-Token实现RBAC权限模型的过程解析,本文给大家介绍的非常详细,对大家的学... 目录前言一、基础概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 环境准备二、表结

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

Jvm sandbox mock机制的实践过程

《Jvmsandboxmock机制的实践过程》:本文主要介绍Jvmsandboxmock机制的实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景二、定义一个损坏的钟1、 Springboot工程中创建一个Clock类2、 添加一个Controller

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o

MybatisPlus3.3.1整合clickhouse的过程

《MybatisPlus3.3.1整合clickhouse的过程》:本文主要介绍MybatisPlus3.3.1整合clickhouse的过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定... 前言ClickHouse是俄罗斯Yandex发布的一款数据分析型数据库支持sql语法,详情可以访问官网,

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File