news 2026/4/2 5:03:08

某聘新版AST解混淆(青春版)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
某聘新版AST解混淆(青春版)

最近网站大更了一次,代码和结构都变了,某聘的混淆还是挺复杂的,不解硬补的话非常头疼,有很多检测点都发现不了。

但是本人AST技术有限,只能做到把三元表达式,函数定义,三重Switch转一重,也是边写边学了。
三元表达式和去除函数定义就不说了,具体流程就看 某直聘逆向之AST处理加密代码
解混淆之后如图:

本文主要讲三重Switch转一重的具体流程:

第一个大控制流,有三层,最后一层有Switch和ifelse两种表达形式(如上图):

第二个控制流:

第二个控制流有四层。

我的逻辑是:

1.先准备好反推控制流的函数,分上面一个的和下面一个控制流的,上面那个文章也写了的,如:

function calculateP1(qbl, Ybl, $bl) { // 检查参数是否在 0-31 范围内(5位二进制最大值) if (qbl< 0 || qbl > 31) throw new Error('qbl must be between 0 and 31'); //第一层 if (Ybl < 0 || Ybl > 31) throw new Error('Ybl must be between 0 and 31');//第er层 if ($bl < 0 || $bl > 31) throw new Error('$bl must be between 0 and 31');//第san层 return ($bl << 10) | (Ybl << 5) | qbl; } function calculateP2(rp, np, ip, sp) { return (sp << 6) | (ip << 4) | (np << 2) | rp; }

2.我是直接遍历的For循环,因为代码里面也不多,随后只全部替换下面的大Switch,到第三层就能需要判断是Switch还是IFelse了。

3.随后就是判断:

if (t.isSwitchStatement(IfStatement_or_SwitchStatement)){ //是否是Switch //循环IfStatement_or_SwitchStatement然后这里push出只有三层的部分 ... if (third_caseNode.consequent[0].type!=='VariableDeclaration'){ 判断是第一个大控制流的 }else{ //这里是走第二个控制流的,是四层, //循环然后push出四层的 } }else{ let search_result=SearchIfStatement(IfStatement_or_SwitchStatement) }

4.把数组转换成Switch(在每个ForStatement内部替换):

5.然后导出js

最终效果就是

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/29 2:09:19

【教学类-89-13】20251212新年篇09——实心点状福字贴对联(通义万相AI福字实心字+点子,传统字体+儿童风格字体)

背景需求: 【教学类-89-12】20251210新年篇08——实心福字贴对联(通义万相AI福字实心字,传统字体+儿童风格字体)https://mp.csdn.net/mp_blog/creation/editor/155770807 小班孩子描灰色福字的问题: 1、画的面积大,画了一部分结构后,幼儿表示:“”我不想画了“ 2、…

作者头像 李华
网站建设 2026/4/1 3:19:03

基于Spring Boot框架和vue的的社区助老志愿者服务中心_k10oo7xf

目录已开发项目效果实现截图已开发项目效果实现截图开发技术系统开发工具&#xff1a;核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部…

作者头像 李华
网站建设 2026/4/1 3:40:44

Prometheus和Granafa监控方案

Prometheus和Granafa监控方案 介绍 Prometheus本身不会直接去抓取应用指标&#xff0c;而是通过对应的Exporter来暴露指标。因此&#xff0c;我们需要在服务器上部署相应的Exporter&#xff0c;并确保它们正在运行且暴露指标在特定端口。 Prometheus通过应用暴露的指标获取数据…

作者头像 李华
网站建设 2026/3/30 13:32:10

上位机状态机开发之正常生产

上位机状态机开发之正常生产 一 正常生产之开始运行/// <summary>/// 开始运行/// </summary>/// <param name"sender"></param>/// <param name"e"></param>private void materialButton6_Click(object sender, Even…

作者头像 李华
网站建设 2026/3/31 7:48:25

回流用户判定

思路&#xff1a;所有用户 活跃用户 回流用户。回流即N天以上未活跃过的用户&#xff0c;这个量级太大&#xff0c;所以要取反&#xff0c;去记录最近N天活跃过的用户uid。使用redis存储&#xff0c;set类型&#xff0c;每天都分为1024个key&#xff0c;这样1天内活跃百万级别…

作者头像 李华
网站建设 2026/4/2 22:29:25

【PYTHON】python venv创建虚拟环境,非conda

电脑里先安装自己需要的python&#xff0c;然后就可以创建自己的环境了 1. 在当前目录创建虚拟环境 python -m venv yolo_env 2. 激活虚拟环境 如果你是Windows系统&#xff0c;使用&#xff1a; yolo_env\Scripts\activate 3. 删除环境 直接删除yolo_env目录即可

作者头像 李华